wang2679958237 2015-04-22 14:42 采纳率: 15.8%
浏览 1702
已采纳

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

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

  • 写回答

7条回答 默认 最新

  • 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();
    }//判断是否为‘#’,如果不是则打印相应的次数
    

    }

    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

  • ¥100 X轴为分离变量(因子变量),如何控制X轴每个分类变量的长度。
  • ¥30 求给定范围的全体素数p的(p-2)的连乘积
  • ¥15 VFP如何使用阿里TTS实现文字转语音?
  • ¥100 需要跳转番茄畅听app的adb命令
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计