带你学C带你飞第19节课动动手,为什么字符对应的ASCII码加1
要求 A:统计用户输入的所有字符个数;版权属于:要求 B:统计不同的字符个数,并打印出来;
要求 C:找出出现次数最多的字符。
#include <stdio.h>
#include <string.h>
#define NUM 128
int main()
{
int ch, i, j = 0, max = 0;
int input_num = 0;
int ascii = {0};
char count = "";
printf("请输入英文文本:");
while ((ch = getchar()) != '\n')
{
ascii++; // 字符对应的ASCII码加1
input_num++;
}
for (i = 0; i < NUM; i++)
{
if (ascii)
{
count = i;
if (ascii > ascii)
{
max = i;
}
}
}
printf("你总共输入了%d个字符,其中不同的字符个数有%d个。\n", input_num, strlen(count));
printf("它们是:%s\n", count);
printf("出现次数最多的字符是\'%c\',它总共出现了%d次。\n", max, ascii);
return 0;
}
看得比较蒙 ascii++; // 字符对应的ASCII码加1
你的代码中 ascii 是数组,共有 128 个元素(刚好对应 ASCII 编码),你的代码是以数组下标当作 ASCII 编码,而值当作次数。
数组下标:ASCII 编码
数组元素值:次数 首先你得了解下数组的知识:数组知识传送门
然后再了解下ASCII码的知识:ASCII 字符表
ascii++; // 字符对应的ASCII码加1
这句应该理解为:对应ASCII码序号的那个数组的值加一,一开始ascii = {0}
将数组的每个值初始化为0了,每ascii++后就相当于这个序号对应的字符输入了一次
PriceXiao 发表于 2022-1-11 12:02
首先你得了解下数组的知识:数组知识传送门
然后再了解下ASCII码的知识:ASCII 字符表
谢谢 PriceXiao 发表于 2022-1-11 12:02
首先你得了解下数组的知识:数组知识传送门
然后再了解下ASCII码的知识:ASCII 字符表
这个其实也用到散列函数,哈希表原理、、我去搜了下确实如此 傻眼貓咪 发表于 2022-1-10 22:56
你的代码中 ascii 是数组,共有 128 个元素(刚好对应 ASCII 编码),你的代码是以数组下标当作 ASCII...
这个其实是不是也用到散列函数,哈希表原理 周云成 发表于 2022-1-11 21:18
这个其实是不是也用到散列函数,哈希表原理
不用把它想复杂了~{:10_254:}{:10_254:}{:10_254:} 傻眼貓咪 发表于 2022-1-10 22:56
你的代码中 ascii 是数组,共有 128 个元素(刚好对应 ASCII 编码),你的代码是以数组下标当作 ASCII...
真是厉害,,把每次输入的字符转化为次数, 傻眼貓咪 发表于 2022-1-11 21:23
不用把它想复杂了~
hh,这个哈希表也是把复杂问题简单化的一个方法啦 周云成 发表于 2022-1-11 21:39
真是厉害,,把每次输入的字符转化为次数,
{:10_254:}
页:
[1]