P8680 [蓝桥杯 2019 省 B] 特别数的和

题目描述

小明对数位中含有 2、0、1、9 的数字很感兴趣(不包括前导 0),在 1 到 40 中这样的数包括 1、2、9、10 至 32、39 和 40,共 28 个,他们的和是 574。

请问,在 1 到 n 中,所有这样的数的和是多少?

输入格式

输入一行包含一个整数 n。

输出格式

输出一行,包含一个整数,表示满足条件的数的和。

输入输出样例

输入 #1

复制代码
40

输出 #1

复制代码
574

说明/提示

对于 20% 的评测用例,1≤n≤10。

对于 50% 的评测用例,1≤n≤100。

对于 80% 的评测用例,1≤n≤1000。

对于所有评测用例,1≤n≤10000。

蓝桥杯 2019 省赛 B 组 F 题。



cpp 复制代码
#include <iostream>
#include <string>
using namespace std;
int main()
{
	int n, i, sum;
	cin >> n;
	string a = "2", b = "0", c = "1", d = "9";
	for (i = 1,sum = 0; i <= n; i++)
	{
		string I = to_string(i);
		string::size_type idx;
		idx = I.find(a);
		if (idx == string::npos);		//不存在,无操作
		else
		{
			sum = sum + i;		//符合条件,求和
			continue;
		}
		idx = I.find(b);
		if (idx == string::npos);		//不存在,无操作
		else
		{
			sum = sum + i;		//符合条件,求和
			continue;
		}
		idx = I.find(c);
		if (idx == string::npos);		//不存在,无操作
		else
		{
			sum = sum + i;		//符合条件,求和
			continue;
		}
		idx = I.find(d);
		if (idx == string::npos);		//不存在,无操作
		else
		{
			sum = sum + i;		//符合条件,求和
		}
	}
	cout << sum;
	return 0;
}

此题易疏忽的点是忘记用continue语句,导致如"21"这样同时含有2和1的数多次重复求和!



本解法使用了"字符串中查找另一个字符串的函数find",这样可以判断"字符串里面是否含有某个字符串"。功能为在string对象中,查找参数string类型的字符串是否存在,如果存在,返回起始位置。不存在则返回 string::npos

其重载形式为:

string::size_type string::find(string &);

注:头文件要包含**#include<string>**

---------------------------------------------------------------------------------------------------------------------------------

参考代码如下:

cpp 复制代码
     string a = "xyz123";
     string b = "y";
     string c = "2";
     string::size_type idx;
     idx = a.find(b);    //在a中查找b.
     if (idx == string::npos )    //不存在
         cout << "0";
     else    //存在。
         cout << "1"; 
     idx = a.find(c);    //在a中查找c。
     if (idx == string::npos)    //不存在
         cout << "0";
     else    //存在。
         cout << "1"; 

如此,使用find函数是不是方便我们许多呢~

祝看到这里的伙伴学C有成!

相关推荐
老马啸西风10 分钟前
力扣 LC27. 移除元素 remove-element
算法·面试·github
数智顾问14 分钟前
中秋特别篇:使用QtOpenGL和着色器绘制星空与满月——从基础框架到光影渲染
算法
txwtech17 分钟前
第5篇 如何计算两个坐标点距离--opencv图像中的两个点
人工智能·算法·机器学习
CoovallyAIHub17 分钟前
YOLO26学界首评:四大革新点究竟有多强?
深度学习·算法·计算机视觉
用户9163574409517 分钟前
LeetCode热题100——11.盛最多水的容器
javascript·算法
Gorgous—l31 分钟前
数据结构算法学习:LeetCode热题100-矩阵篇(矩阵置零、螺旋矩阵、旋转图像、搜索二维矩阵 II)
数据结构·学习·算法
2401_841495641 小时前
【计算机视觉】霍夫变换函数的参数调整
人工智能·python·算法·计算机视觉·霍夫变换·直线检测·调整策略
练习前端两年半1 小时前
🔍 你真的会二分查找吗?
前端·javascript·算法
澄澈i2 小时前
CMake学习篇[3]---CMake进阶+嵌套CMakeLists+多层级关系
c++·学习·cmake
搂鱼1145142 小时前
GJOI 10.7/10.8 题解
算法