鱼C论坛

 找回密码
 立即注册
查看: 3016|回复: 5

关于C语言的一道题

[复制链接]
发表于 2012-3-8 16:53:36 | 显示全部楼层 |阅读模式
1鱼币
本帖最后由 Yogurt_lei 于 2012-3-16 10:23 编辑

怎么求解
输入字符串中出现次数最多的字符串啊.


C语言新手提问.
谢谢大家了

最佳答案

查看完整内容

优化后的代码 #include #include #include int jiecheng(int i); int main(void){ char * str ="aaaabbbbbccccccddaaaa"; int len = strlen(str); unsigned char *index = (unsigned char *)calloc(len,sizeof(char)); char c1 ; //保存出现次数最多的字符 int count1; //保存出现的次数 int count3; count1 = 0; count3 = 0; for( int i = 0; i < len; i ++) { int count2 = 1; for(in ...
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2012-3-8 16:53:37 | 显示全部楼层
优化后的代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int jiecheng(int i);
int main(void){
        char * str ="aaaabbbbbccccccddaaaa";
        int len = strlen(str);
        unsigned char *index = (unsigned char *)calloc(len,sizeof(char));
        char c1 ;  //保存出现次数最多的字符
        int count1;  //保存出现的次数
        int count3;
        count1 = 0;
        count3 = 0;
        for( int i = 0; i < len; i ++)
        {
                  int count2 = 1;
                  for(int j = i + 1; j < len; j++)
                  {
                                if(index[j] == 1)
                                        continue;
                                if(str[i] == str[j])
                                {
                                        index[j] = 1;
                                        count2 ++;
                                }
                                count3 ++;
                  }
                  c1 = count2 > count1 ? str[i] : c1;
                  count1 = count2 > count1 ? count2 : count1;
        }

        printf("字符%c以%d的次数获得了字符王的称号!!",c1,count1);
        printf("优化后的程序比先前少查询了%d次",jiecheng(len -1) - count3);
        return 0;
}

int jiecheng(int i)
{
        if(i<0) return NULL;
        if(i==1) return 1;
        return (i += jiecheng(i-1));
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2012-3-9 13:00:02 | 显示全部楼层
貌似只能弄出N个数组,一个个i++直到结尾了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2012-3-9 13:30:06 | 显示全部楼层
假如是输入英文字母的的话,就设定一个一维数组a[26],每个字母对应一个值,然后用switch case 语句循环,每出现一个对应的字母,比如a则a[0]++,最后找出数组中最大的值就可以了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2012-3-9 17:52:24 | 显示全部楼层

不是啊,是输入 多个 字符串 找到 出现次数最多的  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2012-3-16 06:30:15 | 显示全部楼层
本帖最后由 wAterLoo 于 2012-3-16 07:14 编辑

下面是思路,暂时不支持中文查找
代码还可以优化
#include <stdio.h>
#include <string.h>
int main(void){
    char * str ="aaaabbbbbccccccddaaaa";
    int len = strlen(str);        
    char c1 ;  //保存出现次数最多的字符
    int count1;  //保存出现的次数

    count1 = 0;
    for( int i = 0; i < len; i ++)
    {
          int count2 = 1;
          for(int j = i + 1; j < len; j++)
          {
                if(str == str[j])
                {
                    count2 ++;
                }
          }
          c1 = count2 > count1 ? str : c1;
          count1 = count2 > count1 ? count2 : count1;
    }

    printf("字符%c以%d的次数获得了字符王的称号!!",c1,count1);
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-27 11:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表