【题解】 [蓝桥杯 2019 省 B] 特别数的和

题目描述

小明对数位中含有 222、000、111、999 的数字很感兴趣(不包括前导 000),在 111 到 404040 中这样的数包括 111、222、999、101010 至 323232、393939 和 404040,共 282828 个,他们的和是 574574574。

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

输入格式

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

输出格式

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

输入输出样例 #1

输入 #1

复制代码
40

输出 #1

复制代码
574

说明/提示

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

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

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

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

蓝桥杯 2019 省赛 B 组 F 题。

题目分析

目的:统计满足条件的数的和。

阅读可知,需要满足的条件是:数位中含有2,0,1,92,0,1,92,0,1,9的数字。我们可以遍历1∼n1\sim n1∼n中的每个数字,逐个判断是否满足条件,将满足的条件的数字进行累加。对于条件的判断,我们可以将数字进行拆位,将拆出的每一位数字进行比较。

cpp 复制代码
//拆位
while(x){
  int u=x%10;//数位值
  x/=10;
}

代码实现

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
using i64 = long long;
const int N = 1e5 + 5;
bool chk(int x){
	//拆位
	while(x){
		int u=x%10;
		//判断是否是2,0,1,9中的一位
		if(u==2||u==0||u==1||u==9)
			return 1;
		x/=10;
	}
	//不符合条件
	return 0;
}
int main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	cout.tie(nullptr);
	int n,sum=0;
	cin>>n;
	//遍历所有数字
	for(int i=1;i<=n;i++){
		//满足条件的数字进行累加
		if(chk(i)) sum+=i;
	}
	cout<<sum;
	return 0;
}
相关推荐
式516几秒前
线性代数(九)线性相关性、基与维数
线性代数·算法·机器学习
啊阿狸不会拉杆1 分钟前
《数字图像处理》第7章:小波变换和其他图像变换
图像处理·人工智能·python·算法·机器学习·计算机视觉·数字图像处理
炽烈小老头2 分钟前
【 每天学习一点算法 2025/12/17】验证二叉搜索树
学习·算法
用户271995372138 分钟前
基于Label Studio 集成视觉大模型Qwen2-VL和yolo实现自动标注
算法
智者知已应修善业30 分钟前
【删除有序数组中的重复项 II之O(N)算法】2024-1-31
c语言·c++·经验分享·笔记·算法
patrickpdx39 分钟前
leetcode:环形链表
算法·leetcode·链表
资深web全栈开发40 分钟前
LeetCode 3652: 按策略买卖股票的最佳时机
算法·leetcode·职场和发展
Wang ruoxi1 小时前
基于最小二乘法的离散数据拟合
人工智能·算法·机器学习
Xの哲學1 小时前
Linux链路聚合深度解析: 从概念到内核实现
linux·服务器·算法·架构·边缘计算
加成BUFF1 小时前
C++入门讲解3:数组与指针全面详解
开发语言·c++·算法·指针·数组