信息学奥赛一本通 1129:统计数字字符个数 | OpenJudge NOI 1.7 01
生活随笔
收集整理的这篇文章主要介绍了
信息学奥赛一本通 1129:统计数字字符个数 | OpenJudge NOI 1.7 01
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
【题目链接】
ybt 1129:统计数字字符个数
OpenJudge NOI 1.7 01:统计数字字符个数
【题目考点】
1. 字符串处理
- 声明字符数组:char s[100];(数组长度根据实际情况而定)
- 输入字符串:cin>>s;(字符串中无空格),cin.get(s, 100);(字符串中有空格)
- 获取字符串长度:int len = strlen(s);
- 遍历字符数组for(int i = 0; i < len; ++i){/*遍历操作*/}
2. 读取带空格的字符串
- 使用字符数组:char s[100];
- 可以使用函数cin.get(字符数组名, 最大读取长度),如:cin.get(s, 100);
- 可以使用fgets(字符数组名, 最大读取长度, stdin),如:fgets(s, 100, stdin);
- 函数gets(字符数组名),例gets(s);,不推荐使用。由于gets()不检查字符串的大小,必须遇到换行符或文件结尾才会结束输入,因此容易造成缓存溢出的安全性问题,导致程序崩溃,通常情况下没有问题,但不推荐使用。
- 使用string类:string s;
- 使用getline函数,getline(cin, string类对象),例:getline(cin, s);
【题解代码】
解法1:
使用字符数组
#include <bits/stdc++.h> using namespace std; int main() {char s[260];cin.get(s, 260);int sum = 0, len = strlen(s);for(int i = 0; i < len; ++i){if(s[i] >= '0' && s[i] <= '9')sum++;}cout<<sum;return 0; }解法2:
使用string类
#include <bits/stdc++.h> using namespace std; int main() {string s;getline(cin, s);int sum = 0;for(int i = 0; i < s.length(); ++i){if(isdigit(s[i]))//使用<ctype.h>中的类型判断函数sum++;}cout<<sum;return 0; }总结
以上是生活随笔为你收集整理的信息学奥赛一本通 1129:统计数字字符个数 | OpenJudge NOI 1.7 01的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: 信息学奥赛一本通(1177:奇数单增序列
- 下一篇: 信息学奥赛一本通 1978:【18NOI