wang2679958237
wang2679958237
采纳率15.8%
2015-04-22 14:42 阅读 1.7k
已采纳

一道C语言编程题,本人初学者,求大神解答

编写程序实现功能:数据文件story.txt是一篇英文小故事,请先统计其中26个字母的出现次数。
要求一:再根据用户要求,输出某个字母的出现次数,直到用户输入#为止。
要求二:请输出出现频率最高的三个字母和它们的出现次数。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

7条回答 默认 最新

  • 已采纳
    BensonLaur BensonLaur 2015-04-22 15:40

    #include
    #include
    #include
    int main()
    {
    int alpha[26]={0}; //用于计数26个字母出现的次数
    FILE *text; //FILE 指针
    char ch;

    if((text=fopen("Story.txt","r"))== NULL){
        printf("File open error!");
        exit(0);
    }//如果没有文件则提示错误
    
    while((ch=fgetc(text))!=EOF){
        ch = tolower(ch);
        if(ch>='a'&&ch<='z'){
            alpha[ch-'a']++;
        }
    }//将每个字母出现的次数存放到lpha数组中
    fclose(text);
    
    int isSelected[26] ={0};//用于标记是否已经被选为前三个
    int i;
    int FIndex=0,SIndex=0,TIndex=0;//分别记录前三个字母的下标
    int MaxNum = 0;
    for(i=0;i<26;i++){
        if(!isSelected[i]){
            if(alpha[i]>MaxNum){
                FIndex = i;
                MaxNum = alpha[i];
            }
        }
    }
    isSelected[FIndex] = 1; //在未被选择的字母中比较出当前次数最多的,则为第一个
    
    MaxNum = 0;
    for(i=0;i<26;i++){
        if(!isSelected[i]){
            if(alpha[i]>MaxNum){
                SIndex = i;
                MaxNum = alpha[i];
            }
        }
    }
    isSelected[SIndex] = 1;//在未被选择的字母中比较出当前次数最多的,则为第二个
    
    MaxNum = 0;
    for(i=0;i<26;i++){
        if(!isSelected[i]){
            if(alpha[i]>MaxNum){
                TIndex = i;
                MaxNum = alpha[i];
            }
        }
    }
    isSelected[TIndex] = 1;//在未被选择的字母中比较出当前次数最多的,则为第三个
    
    printf("前三个字母:%c %c %c\n出现的次数:%d %d %d\n\n",'a'+FIndex,'a'+SIndex,'a'+TIndex,
           alpha[FIndex],alpha[SIndex],alpha[TIndex]);
    
    printf("Enter a Letter to check its count(end with input #):\n\n");
    while((ch=getchar())!='#'){
        ch = tolower(ch);
        if(ch<'a'|| ch>'z')printf("Enter a letter !\n");
        else {
            printf("time(s):%d\n",alpha[ch-'a']);
        }
        getchar();
    }//判断是否为‘#’,如果不是则打印相应的次数
    

    }

    
    
    点赞 1 评论 复制链接分享
  • danielinbiti danielinbiti 2015-04-22 14:48
  • devmiao devmiao 2015-04-22 15:08

    代码自己去搜google,这里说思路
    定义一个数组,26个元素长,遍历你的字符串,然后放入对应的下标(因为字母在ascii是连续的,只要用字符减'a'就可以得到下标,不需要switch,为了避免特殊字符,对结果判断下是不是0-25)
    然后遍历完了就统计好了。

    点赞 1 评论 复制链接分享
  • BensonLaur BensonLaur 2015-04-22 15:43

    怎么回复功能这么不好,提供的代码显示模块这么不好,还把我打的代码漏显示了一些,无语了,

    点赞 评论 复制链接分享
  • BensonLaur BensonLaur 2015-04-22 15:46

    前三个头文件为:
    #include
    #include // exit(int num); 退出并返回数字num结束
    #include // tolower(char ch); 把ch转换为小写字母

    点赞 评论 复制链接分享
  • BensonLaur BensonLaur 2015-04-22 15:48

    原来只有头文件显示不了。。。
    stdio.h>
    stdlib.h>
    ctype.h>

    点赞 评论 复制链接分享
  • BensonLaur BensonLaur 2015-04-22 15:56

    这道题的重点在于文件的 读写操作和字母的判断
    难点在于 怎么满足题目要求:要显示前三个字母,又要让用户随便输入来查看

    读写操作和字母的判断 下面的代码里有,对于我说的难点,解决办法是:除了创建储存字母数的alpha数组,为了不破坏alpha里的内容,额
    外创建了一个isSelected数组来标记元素是否被选为前三个字母。

    点赞 评论 复制链接分享

相关推荐