CCF-CSP第18次认证第一题——报数【两个与string相关的函数的使用】

CCF-CSP第18次认证第一题------报数

官网链接:TUOJ

时间限制: 1.0 秒

空间限制: 512 MB

下载题目目录(样例文件)

题目描述

甲乙丙丁决定玩一个报数的游戏来打发时间。游戏规则为四个人从 11 开始轮流进行报数,但如果需要报出的数是 77 的倍数或含有数字 77 则直接跳过。

此外大家约定,在总共报出了 𝑛n 个数后(不计入被跳过的数)游戏结束。现在需要你来帮忙统计,游戏过程中每个人各自跳过了几次。

输入格式

从标准输入读入数据。

输入仅一行,包含一个正整数 𝑛n,表示报出了多少个数后游戏结束。

输出格式

输出到标准输出。

输出共四行,每行一个整数,依次表示甲乙丙丁四人在游戏过程中跳过的次数。

样例1输入

复制代码
20

样例1输出

复制代码
2
1
1
0

样例1解释

报数过程为:

复制代码
甲:1,乙:2,丙:3,丁:4
甲:5,乙:6,丙:跳过,丁:8
甲:9,乙:10,丙:11,丁:12
甲:13,乙:跳过,丙:15,丁:16
甲:跳过,乙:18,丙:19,丁:20
甲:跳过,乙:22,丙:23,丁:24

在丁报出 2424 后,四个人总计报出了 2020 个数,游戏结束。

样例2输入

复制代码
66

样例2输出

复制代码
7
5
11
5

子任务

  • 测试点 11、22、33、44 和 55,保证 𝑛≤102n≤102;
  • 测试点 66、77、88、99 和 1010,保证 𝑛≤666n≤666。

参考题解

cpp 复制代码
#include <iostream>
#include <vector>

using namespace std;

int main () {
	int n;
	cin >> n;
	vector<int> count (4, 0);
	int number = 1;
	int skip = 0;
	bool flag = true;
	while(flag) {
		for(int i = 0; i < 4; i++, number++) {
			if(number > n + skip) {
				flag = false;
				break;
			}
			if(number % 7 == 0 || to_string(number).find('7') != string::npos) {
				count[i]++;
				skip++;
			}
		}
	}
	for(int i = 0; i < 4; i++) {
		cout << count[i] << "\n";	
	}
	
	return 0;
}

总结

刚开始看题目心想这还不简单,分分钟搞定,结果发现自己不知道int转string**【to_string(int)】** 以及string中查找指定字符**【string.find(char)】**的函数,在网上搜索后完成编程,但是运行结果又不对,一直是1110,看了半天才发现错误

  1. to_string(number).find('7')如果未找到返回的是string::npos,是一个特定数值,并不是0或者null什么的,所以if语句中不能直接只用这个
  2. 题目中说的n是不算跳过的数的,是要报n个数,跳过的数是不用报的,所以还要加上skip
  3. 在合适的地方输出中间结果,看和自己预期哪里不一样,有助于debug
相关推荐
aaaweiaaaaaa21 分钟前
c++基础学习(学习蓝桥杯 ros2有C基础可看)
c++·学习·蓝桥杯·lambda·ros2·智能指针·c++类
MadPrinter30 分钟前
SpringBoot学习日记 Day11:博客系统核心功能深度开发
java·spring boot·后端·学习·spring·mybatis
一拳一个呆瓜43 分钟前
【MFC】对话框属性:字体 (Font Name) 和 大小 (Font Size)
c++·mfc
郝学胜-神的一滴1 小时前
基于OpenGL封装摄像机类:视图矩阵与透视矩阵的实现
c++·qt·线性代数·矩阵·游戏引擎·图形渲染
啊?啊?1 小时前
14 C++ STL 容器实战:stack/list 模拟实现指南 + priority_queue 用法及避坑技巧
c++·
汉克老师1 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(4、最大空白区)
c++·算法·蓝桥杯·蓝桥杯c++·c++蓝桥杯
wanzhong23332 小时前
ArcGIS学习-18 实战-降雨量空间分布插值分析
学习·arcgis
wanzhong23332 小时前
ArcGIS学习-19 实战-表面分析
学习
我命由我123452 小时前
Photoshop - Photoshop 创建文档
学习·ui·课程设计·设计·photoshop·ps·美工
羚羊角uou2 小时前
【Linux】匿名管道和进程池
linux·c++·算法