鱼C论坛

 找回密码
 立即注册
查看: 2685|回复: 2

[技术交流] 数位拆分 例题 1

[复制链接]
发表于 2023-1-17 22:04:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述

给定一个整数, 输出这个数的数位中包含数字 44 的个数.
输入描述

输入数据的第一行, 包含一个整数 T  ,T, 表示询问的组数.
接下来的 TT 行, 每行包含一个整数.
=== 数据范围 ===

    1≤T≤1051≤T≤105
    子问题 1: 0≤输入的整数≤90≤输入的整数≤9 . (30 分)
    子问题 2: 0≤输入的整数≤1090≤输入的整数≤109 . (70 分)

输出描述

对于每组测试数据, 输出一行一个整数表示对应的答案.
样例1
  1. 5
  2. 447474
  3. 228
  4. 6664
  5. 40
  6. 81
复制代码

输出
  1. 4
  2. 0
  3. 1
  4. 1
  5. 0
复制代码

答案
游客,如果您要查看本帖隐藏内容请回复

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
柿子饼同学 + 5 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-1-17 22:21:24 | 显示全部楼层
1.png

是不是复制出来有问题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-1-17 22:44:36 | 显示全部楼层
不需要自己拆,用标准库里面的函数很容易实现这个题目要求

  1. sh-5.1$ ls
  2. main.cpp
  3. sh-5.1$ cat main.cpp
  4. #include <iostream>
  5. #include <string>
  6. #include <limits>
  7. #include <algorithm>

  8. int main() {
  9.     size_t n; std::cin >> n;
  10.     std::cin.ignore(std::numeric_limits<std::streamsize>::max(), '\n');
  11.     for(size_t i = 0; i < n; ++i) {
  12.         std::string line; std::getline(std::cin, line);
  13.         size_t count = std::count(line.begin(), line.end(), '4');
  14.         std::cout << count << std::endl;
  15.     }
  16.     return 0;
  17. }
  18. sh-5.1$ g++ -g -Wall -o main main.cpp
  19. sh-5.1$ ls
  20. main  main.cpp
  21. sh-5.1$ ./main
  22. 5
  23. 447474
  24. 228
  25. 6664
  26. 40
  27. 81
  28. 4
  29. 0
  30. 1
  31. 1
  32. 0
  33. sh-5.1$
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-23 01:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表