鱼C论坛

 找回密码
 立即注册
查看: 1732|回复: 4

[已解决]新人求助,关于字符串处理函数

[复制链接]
发表于 2020-2-14 17:41:17 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <stdio.h>
#include <string.h>

#define NUM 128

int main()
{
        int ch, i, j = 0, max = 0;
        int input_num = 0;
        int ascii[NUM] = {0};
        char count[NUM] = "";

        printf("请输入英文文本:");

        while ((ch = getchar()) != '\n')
        {
                ascii[ch]++; // 字符对应的ASCII码加1
                input_num++;
        }

        for (i = 0; i < NUM; i++)
        {
                if (ascii[i])
                {
                        count[j++] = i;
                        if (ascii[i] > ascii[max])
                        {
                                max = i;
                        }
                }
        }

        printf("你总共输入了%d个字符,其中不同的字符个数有%d个。\n", input_num, strlen(count));
        printf("它们是:%s\n", count);
        printf("出现次数最多的字符是\'%c\',它总共出现了%d次。\n", max, ascii[max]);

        return 0;
}

这个程序中,基本都能理解字符串数组分别起到什么作用。
只有 count 这个这个字符串数组,它是怎么把字符存进去的,count[j++] = i; 这里的 j 跟 i 不是循环语句的计算器吗?

而且字符串中输出的每个元素都是唯一的
就是不太清楚是哪里把字符存进count里面去的,然后输出也是不重复输出相同字符
最佳答案
2020-2-14 18:08:33
数组ascii用来统计出现过的字符的个数
count是一个字符串
j不是循环的计数器,而是count字符串元素的计算器
在count[j++] = i;这句把出现过的字符(也就是ascii[i]不等于0的)一个一个存进count的元素里
最后输出这个字符串
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-2-14 18:08:33 | 显示全部楼层    本楼为最佳答案   
数组ascii用来统计出现过的字符的个数
count是一个字符串
j不是循环的计数器,而是count字符串元素的计算器
在count[j++] = i;这句把出现过的字符(也就是ascii[i]不等于0的)一个一个存进count的元素里
最后输出这个字符串
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-14 21:08:53 | 显示全部楼层
本帖最后由 4goodworld 于 2020-2-14 21:10 编辑

我觉得这个问题你要从 #define NUM 128开始去理解
为啥NUM是128,因为整个ascii的范围就是0-0xff,总的取值范围就是128个数
当你输入A的时候,其实A的ascii值65,那么ch=65
ascii[ch]这个啥意思,其实可以理解为 ascii这个数组的第65(其实从零开始是第66个)位上的值,而这个值是多少,是++,也就是自加1,每次你输入一个A,这个65位上的值就+1,你输入10个A,那么这个位置的值为65
接着,然后你再理解
 if (ascii[i])
这个if的意思就是得i这个位置所取得的值要>0,而什么时候大于零?根据前面的显示,就是当有某个字符输入的时候,它才会大于零,
接着是这个判断里面:
count[j++] = i;
i代表是什么,其实就是0-128位的acsii的数,其实都无所谓了,关键是j++,就是让count这个数组里面的成员+1,最后你看count参与运算,就是strlen(count)),这个是计算这个count数组(字符串)的长度,如果你prtintf下,你会发现当你实际输入“abcad”的时候,count输出“abcd”,即其中不同的字符个数



想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-2-14 21:26:03 | 显示全部楼层
4goodworld 发表于 2020-2-14 21:08
我觉得这个问题你要从 #define NUM 128开始去理解
为啥NUM是128,因为整个ascii的范围就是0-0xff,总的取 ...

就是说,0-128逐一判断,如果ascii[i]>0,就把这个数字加进count里面,但是因为是用char定义的数组,所以输出的就是对应的acsii的字符对吗?
如果是这样那就理解了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-14 22:23:12 | 显示全部楼层
言覃Jack 发表于 2020-2-14 21:26
就是说,0-128逐一判断,如果ascii>0,就把这个数字加进count里面,但是因为是用char定义的数组,所以输出 ...
ascii[i]>0
意味着比如ascii值=65(也就是A)是你输入的内容之一
至于
count[j++] = i
i就是对应的ascii值,正如你所言,count里面加了一个对应的acsii的字符
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 05:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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