目录
1132:题目描述对于给定的一个字符串,统计其中数字字符出现的次数。字符串长度不超过1000.
1133:题目描述 从键盘输入一行字符,长度小于1000。统计其中单词的个数,各单词以空格分隔,且空格数可以是多个。
1134:题目描述 输入一个以回车结束的字符串,它由数字和字母组成,请过滤掉所有非数字字符,然后将数字字符串转换成十进制整数后乘以2输出。
1.1
1132:题目描述
对于给定的一个字符串,统计其中数字字符出现的次数。字符串长度不超过1000.
输入
输入数据有多行,第一行是一个整数n,表示测试实例的个数,后面跟着n行,每行包括一个由字母和数字组成的字符串。
输出
对于每个测试实例,输出该串中数字字符的个数,每个输出占一行。
1.2
答案:
#include<stdio.h>
int main()
{
int n,i,a=0;
char x;
scanf("%d\n",&n);
for(i=0; i<n; i++)
{
while(scanf("%c",&x),x!='\n')
if(x>='0' && x<='9')
a++;
printf("%d\n",a);
a=0;
}
return 0;
}
2.1
1133:题目描述
从键盘输入一行字符,长度小于1000。统计其中单词的个数,各单词以空格分隔,且空格数可以是多个。
输入
输入只有一行句子。仅有空格和英文字母构成
输出
单词的个数
2.2
答案:
#include<stdio.h>
int main()
{
char a[1001];
int x=0,i;
scanf("%[^\n]",&a);
if(a[0]!=' ')
x=1;
for(i=1; a[i]!='\0'; i++)
if(a[i]!=' ' && a[i-1]==' ')
x++;
printf("%d",x);
return 0;
}
3.1
1134:题目描述
输入一个以回车结束的字符串,它由数字和字母组成,请过滤掉所有非数字字符,然后将数字字符串转换成十进制整数后乘以2输出。
输入
输入一个以回车结束的字符串,长度不超过100,由数字和字母组成。
输出
将转换后的整数乘以2输出,测试数据保证结果在int范围内。
3.2
答案:
#include<stdio.h>
#include<math.h>
int main()
{
char a[100];
int b[100],i,j=0,k,x;
long long int sum=0;
scanf("%[^\n]",&a);
for(i=0; a[i]!='\0'; i++)
if(a[i]>='0' && a[i]<='9')
b[j++]=a[i]-48;
x=j-1;//j代表有几个数字,x控制大小。 例如j=3,三位数,第一个数字*10^2,第二个数字*10^1,第三个数字*10^0
for(k=0; k<j; k++)
sum=sum+b[k]*pow(10,x--);
printf("%lld",sum*2);
return 0;
}
ps:
第二题:
%[^\n]表示到回车结束(回车不算),正常%s以空格为结束标志。
\0是字符串的结束符号。
第二题卡了好久,先开始判定方法为
初始=1, 非空格+空格 计数+1;
这样的bug有:不输入字符串显示1,输入字符串结束后加空格,因为判定方式的原因会多判定一个
然后改思路:初始=1;空格+非空格 计数+1;
这样不输入的bug先不说,就是输入完成后加空格,有时候也会误判定,比如输入:abc t 【结束】,t后面多个空格,我是用的i+1判定后面是否存在非空格,最后一个超出字符串,未知bug,会多判定一次
最后改为:
先判定是不是空格(计数初始=0,因为判定方式的原因,非空格+1),空格+非空格 计数+1,用减法判定,防止超出长度。