| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 787 人关注过本帖
标题:有段代码看不懂,请大家给我讲解下!!谢谢!
取消只看楼主 加入收藏
雪山的猫
Rank: 1
等 级:新手上路
帖 子:44
专家分:5
注 册:2012-12-23
结帖率:95.24%
收藏
已结贴  问题点数:8 回复次数:2 
有段代码看不懂,请大家给我讲解下!!谢谢!
统计字符串出现次数最多的字母!只需要讲解下部分代码就好,不必看完代码(红色地儿)!
#include "stdio.h"
#include "string.h"
char CharCount(char* ch)
{   
   int  big[26]={0};
   int  small[26]={0};
    while(*ch!='\0')
   {
        if ('A'<=*ch &&  *ch<='Z')
            big[*ch-'A'] ++;(我指针比较烂,讲下吧!3qy!!
        else if('a'<=*ch &&  *ch<='z')
            small[*ch-'a'] ++;
        ch++;
   }
   int imax1=0;
   int imax2=0;
   for(int i=0;i<26;i++)
   {
        if(big[i]>big[imax1])
            imax1 = i;
        if(small[i]>small[imax2])
           imax2 = i;
   }
   return (big[imax1]>small[imax2]) ? ('A'+imax1) : ('a'+imax2);
}
void main()
{
  char ch[1024];
  memset(ch,0,sizeof(ch));
  scanf("%s",ch);
  printf(“%c\n" , CharCount(ch) );
}
搜索更多相关主题的帖子: 讲解 谢谢 include 字符串 
2013-04-15 22:11
雪山的猫
Rank: 1
等 级:新手上路
帖 子:44
专家分:5
注 册:2012-12-23
收藏
得分:0 
回复 2楼 bojy123
呵呵!!自己多去看书吧。我也不是很好的代码能力。大家都是这么过来的!
2013-04-16 20:41
雪山的猫
Rank: 1
等 级:新手上路
帖 子:44
专家分:5
注 册:2012-12-23
收藏
得分:0 
回复 2楼 bojy123
#include "stdio.h"
#include "string.h"
char CharCount(char* ch)
{   
   int  big[26]={0};            //存放大写字母
   int  small[26]={0};        //存放小写字母
    while(*ch!='\0')
   {
        if ('A'<=*ch &&  *ch<='Z')     //若ch在A,Z之间,即ch是大写字母,则将big中相应位置的计数加1
            big[*ch-'A'] ++;                //big[0]表示A的个数,big[1]表示B的个数,依次类推
        else if('a'<=*ch &&  *ch<='z')//若ch在a,z之间,即ch是小写字母,则将small中相应位置的计数加1
            small[*ch-'a'] ++;             //small[0]表示A的个数,small[1]表示B的个数,依次类推
        ch++;                                  //指针右移,直到字符为'\0'为止
   }
   int imax1=0;
   int imax2=0;
   for(int i=0;i<26;i++)
   {
        if(big[i]>big[imax1])               //从big[0]开始,找到big[i]最大的i值,存放到imax1中。
            imax1 = i;
        if(small[i]>small[imax2])         //从small[0]开始,找到small[i]最大的i值,存放到imax2中。
           imax2 = i;
   }
   return (big[imax1]>small[imax2]) ? ('A'+imax1) : ('a'+imax2);  //将小写字母出现最多的值与大写字母出现最多的相
                                                         //比,返回更大值
}
void main()
{
  char ch[1024];
  memset(ch,0,sizeof(ch));
  scanf("%s",ch);
  printf(“%c\n" , CharCount(ch) );
2013-05-04 23:10
快速回复:有段代码看不懂,请大家给我讲解下!!谢谢!
数据加载中...
 
   



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

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