统计句子中的小写字母的个数,并输出结果

本文详细解读了一个C语言程序,该程序用于计算字符串中字符的频率,并找出出现次数最多的字符及其重复次数。通过遍历字符串并使用数组存储每个字符的出现次数,然后通过特定的函数输出最大重复次数和对应的字符。程序还包含了对字符串长度的计算以及空格情况的特殊处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

c语言程序:

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

int shuchuzifu(int count[],int j)
{
int k,d=0;

    for(k=0;k<26;k++)
{
    if(count[k]==j)
{
   printf("%c",(char)(k+97));
d=1;
}
}


if(d)
   return 1;
else
   return 0;
}

int main()
{
char *a="wo cheng gong le jin tian shangwu mei you bai lai";
   
int count[26];
int max=0,flag1,flag2=0;
int i=0,j,n,p;
int len,m=0;

len=strlen(a);
    
for(n=0;n<26;n++)//不给count[26]复初值,会出现很多统计数据之类的错误
{
count[n]=0;
}
    printf("字符串长度为:%d\n",len);

  assert(a);
    
    while(a[i])//在此处用i++的话,l=++count[a[i]-97]里的i没有表达出0的意思。
{
   max=(++count[a[i]-97])>max?count[a[i]-97]:max;//重点 这么一句话可等于下面n句
// if(a[i]!=(char)32)//一定要考虑空格的特殊情况
// {
          //    m=++count[a[i]-97];
   //  if(m>max)
 //{
// max=m;
 //}
       flag1=1;
//}
  i++;
}

printf("最大重复个数为:%d个\n",max);

   for(j=1;j<max+1;j++)
{
p=shuchuzifu(count,j);
    if(p)
  printf(":%d个\n",j);
}
if(flag2)
{
printf("No matching\n");
}

return 0;
}



执行结果:

以下是用C语言实现统计输入字符串中大小写字母个数的方法: ### 方法描述 通过遍历输入字符串中的每一个字符,利用 `<ctype.h>` 库中的 `isalpha` 函数判断当前字符是否为字母。如果是字母,则进一步使用 `islower` 和 `isupper` 判断其是小写还是大写,分别累加对应的计数值。 下面是完整的代码示例: ```c #include <stdio.h> #include <ctype.h> int main() { char input[100]; printf("请输入一个字符串: "); fgets(input, sizeof(input), stdin); int lowercase_count = 0; int uppercase_count = 0; for (int i = 0; input[i] != '\0'; i++) { if (isalpha(input[i])) { // 如果是字母 if (islower(input[i])) { // 小写字母 lowercase_count++; } else if (isupper(input[i])) { // 大写字母 uppercase_count++; } } } printf("小写英文字母数: %d\n", lowercase_count); printf("大写英文字母数: %d\n", uppercase_count); return 0; } ``` 此程序实现了以下功能: - 使用 `fgets` 获取用户输入的字符串[^1]。 - 遍历字符串中的每个字符检查它是否为字母[^1]。 - 对于每个字母,进一步分类它是小写还是大写,更新相应的计数器[^1]。 #### 输出说明 运行该程序后,用户可以输入任意字符串,程序会输出中的小写和大写字母数量。 --- ### 扩展功能:统计每种字母的具体出现次数 如果还需要统计每个具体字母(不分大小写)的出现次数,可以通过如下方式扩展代码: ```c #include <stdio.h> #include <ctype.h> int main() { char str[100]; int count[26] = {0}; printf("请输入一个字符串: "); fgets(str, sizeof(str), stdin); for (int i = 0; str[i] != '\0'; i++) { if (isalpha(str[i])) { // 是否为字母 str[i] = tolower(str[i]); // 转换为小写 count[str[i] - 'a']++; // 记录到对应位置 } } for (int i = 0; i < 26; i++) { if (count[i] > 0) { printf("%c 的出现次数: %d\n", i + 'a', count[i]); } } return 0; } ``` 在此版本中: - 定义了一个长度为26的数组 `count` 来存储每个字母的出现次数[^3]。 - 每次遇到字母时将其转换为小写形式,记录到相应索引的位置。 - 最终打印出所有非零计数的字母及其频率[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值