欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

信息学奥赛一本通 1129:统计数字字符个数 | OpenJudge NOI 1.7 01

发布时间:2025/3/17 编程问答 26 豆豆
生活随笔 收集整理的这篇文章主要介绍了 信息学奥赛一本通 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的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。