| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 254 人关注过本帖
标题:这段程序哪里有问题
只看楼主 加入收藏
aptx48691212
Rank: 2
等 级:论坛游民
帖 子:20
专家分:10
注 册:2012-11-21
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
这段程序哪里有问题
/*    请编写函数fun,函数的功能是:移动字符串中的内容,移动的规则如下:把第1到第m个字符平移到字符串的最后,把第m+1到最后的字符移到字符串的前部。
    例如,字符串中原有的内容为:ABCDEFGHIJK,m的值为3,则移动后字符串中的内容应该是:DEFGHIJKABC。
    注意:部分源程序存在文件prog.c中。
    请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。*/



#include <stdio.h>
#include <string.h>
#define    N    80
void  fun(char  *w, int  m)
{
   
    int i,n;
    char t;
    n=strlen(w);
    for(i=0;i<m;i++)
    {
    w[i+n-m+1]=w[i];
        
    }
    for(i=m;i<n;i++)
    {
        w[i-m]=w[i];
    }
   
}

NONO()
{

    FILE *rf, *wf ; char a[N] ; int m, i ;
    rf = fopen("bc.in", "r") ;
    wf = fopen("bc.out", "w") ;
    for(i = 0 ; i < 10 ; i++) {
        fscanf(rf, "%d %s", &m, a) ;
        fun(a, m) ;
        fprintf(wf, "%s\n", a) ;
    }
    fclose(rf) ; fclose(wf) ;
}

main()
{
    char  a[N]= "ABCDEFGHIJK";
    int  m;
    printf("The original string:\n");puts(a);
    printf("\n\nEnter  m:  ");scanf("%d",&m);
    fun(a,m);
    printf("\nThe string after moving:\n");puts(a);
    printf("\n\n");
    NONO();
}
搜索更多相关主题的帖子: include 源程序 字符串 
2012-12-23 00:09
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:20 
思路错了,第一个for循环那

后面的字母已经被前面的覆盖掉了


[fly]存在即是合理[/fly]
2012-12-23 00:59
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
程序代码:
void  fun(char  *w, int  m)
{
    char *temp = (char*)malloc(m + 1);
    strncpy(temp, w, m);
    temp[m] = '\0';
    int len = strlen(w);
    for (int i = 0;m <= len;w[i++] = w[m++]);
    strcat(w, temp);
    free(temp);
}


[fly]存在即是合理[/fly]
2012-12-23 01:05
快速回复:这段程序哪里有问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.040183 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved