每日一题断更一天(补上):1063统计字符

简介: 题目描述:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。输入:无

题目描述:

输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

输入:

输出:

样例输入:

a 1,

样例输出:

1

1

1

1

分析:这道题不难有多种方法,第一种:数组(这一种可能在C语言网上出现错误);第二种:单个输入(个人建议使用这而一种);

有需要自取!

源码1:

include <stdio.h>

include <string.h>

int main(void)

{

int n=20;  //定义
char c[n];    数组
int i,x,a=0,b=0,k=0,d=0;//方便计数,初始值都设为一
gets(c);// 方法得到字符串数组
x=strlen(c);//计算数组长度
for(i=0;i<x;i++){
if((c[i]>64&&c[i]<91)||(c[i]>96&&c[i]<123)){//从a到z,从A到Z,如果是则加一
        a++;
    }else if(c[i]==32){//空格的ASCII码为32,一定要记住,以后会经常用到
        b++;
    }else if(c[i]>47&&c[i]<58){ //数字0到9的ASCII码,同样重要
        k++;
    }else{ //如果是其他字符,则d++;
        d++;
    }
}
printf("%d\n%d\n%d\n%d\n",a,b,k,d);//输出就行了,注意上面的输出案例都换行了
return 0;

}

源码2:(这一种不会出现,指针飘移等问题,建议食用!)

include <stdio.h>

int main(void)

{

int a=0,b=0,k=0,d=0;
char ch;
while(1){
    scanf("%c",&ch);
if(ch=='\n'){
break;
    }
if((ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z')){
        a++;
    }else if(ch==' '){
        b++;
    }else if(ch>='0'&&ch<='9'){
        k++;
    }else{
        d++;
    }
}
printf("%d\n%d\n%d\n%d\n",a,b,k,d);
return 0;

}

目录
相关文章
|
C语言
【Leetcode-1638.统计只差一个字符的字串数目(C语言)】
【Leetcode-1638.统计只差一个字符的字串数目(C语言)】
55 0
LeetCode题解-让所有学生保持开心的分组方法数
LeetCode题解-让所有学生保持开心的分组方法数
|
算法
代码随想录Day21 回溯 LeetCodeT216 组合总和III LeetCode T17电话号码的字母总和
代码随想录Day21 回溯 LeetCodeT216 组合总和III LeetCode T17电话号码的字母总和
65 0
|
9月前
|
C语言
C语言学习记录——将三位数的个十百位单独打印,并求其和。
C语言学习记录——将三位数的个十百位单独打印,并求其和。
64 4
|
10月前
除夕日的每日一题(字符个数统计,多数元素)
除夕日的每日一题(字符个数统计,多数元素)
61 2
|
10月前
|
算法
算法编程(二十九):统计一致字符串的数目
算法编程(二十九):统计一致字符串的数目
110 0
|
存储 数据可视化 算法
字符串之谜:如何找到出现频率最高的字符?
字符串之谜:如何找到出现频率最高的字符?
298 0
刷爆leetcode第十二期 0026 数组中数字出现的次数
刷爆leetcode第十二期 0026 数组中数字出现的次数
112 0
刷爆leetcode第十二期 0026 数组中数字出现的次数
力扣刷题记录——392. 判断子序列、401. 二进制手表、409.最长回文串
力扣刷题记录——392. 判断子序列、401. 二进制手表、409.最长回文串
128 0
力扣刷题记录——392. 判断子序列、401. 二进制手表、409.最长回文串