每日一题断更一天(补上):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;

}

目录
相关文章
亲身经历:如何判断一个字符在a/z之前?
亲身经历:如何判断一个字符在a/z之前?
75 0
|
索引
力扣刷题记录——367. 有效的完全平方数、383. 赎金信、387. 字符串中的第一个唯一字符、389. 找不同
力扣刷题记录——367. 有效的完全平方数、383. 赎金信、387. 字符串中的第一个唯一字符、389. 找不同
147 0
力扣刷题记录——367. 有效的完全平方数、383. 赎金信、387. 字符串中的第一个唯一字符、389. 找不同
|
算法
费解的开关/翻硬币
费解的开关/翻硬币
138 0
|
10月前
除夕日的每日一题(字符个数统计,多数元素)
除夕日的每日一题(字符个数统计,多数元素)
60 2
【刷穿 LeetCode】1894. 找到需要补充粉笔的学生编号 :「前缀和 + 二分」&「模拟」
【刷穿 LeetCode】1894. 找到需要补充粉笔的学生编号 :「前缀和 + 二分」&「模拟」
|
Python C语言
蜗牛爬行日记——判断闰年
过了一个慵懒的周末,进度应该被别的童鞋拉下不少/(ㄒoㄒ)/~~。所以我觉得蜗牛爬行日记这个题目还真是特别应景。 这篇文章是记录一下入门级的程序——如何判断闰年。
998 0
|
机器学习/深度学习
7-20 打印九九口诀表 (15 分)
7-20 打印九九口诀表 (15 分)
145 0
|
测试技术 API
力扣每日一题:278.第一个错误的版本 欢度端午的二分水题!
力扣每日一题:278.第一个错误的版本 欢度端午的二分水题!
115 0
|
10月前
|
人工智能 算法 Java
最长连续不重复子序列(蓝桥杯每日一题)
最长连续不重复子序列(蓝桥杯每日一题)
71 0