用数组编程字符,并统计出字符串中大小写字母的个数

本文介绍了一个简单的C++程序,用于统计输入字符串中大写和小写字母的数量。通过使用数组和条件判断,该程序实现了对字符的有效分类计数。

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

我的程序:

01./*  
02.* 程序的版权和版本声明部分:  
03.* Copyright (c) 2013, 烟台大学计算机学院  
04.* All rights reserved.  
05.* 文件名称:test.cpp  
06.* 作    者:王鲁峰  
07.* 完成日期:2013 年12月2日  
08.* 版 本 号:v1.0  
09.* 对任务及求解方法的描述部分: 
10.* 输入描述:无  
11.* 问题描述:用数组编程字符,并统计出字符串中大小写字母的个数
12.* 程序输入:略  
13.* 程序输出:略 
14.* 算法设计:略  
15.*/    

#include <iostream>
#include <cstdio>
using namespace std;
int main()
{
    char str[50];
    int i=0,n=0,t=0;
    cout<<"输入字符串:";
    gets(str);
    while(str[i]!='\0')
    {
        if(str[i]>=65&&str[i]<=90)
                n++;

        else if(str[i]>=97&&str[i]<=122)
                t++;
                i++;
    }
   cout<<"其中大写字母的个数是:"<<n<<endl;
   cout<<"其中小写字母的个数是:"<<t<<endl;
   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、付费专栏及课程。

余额充值