P10424 [蓝桥杯 2024 省 B] 好数 题解

题目名字 P10424 [蓝桥杯 2024 省 B] 好数 题解

题目链接

题意

给一个整数n,从1到n这个区间范围内,每一个数位为偶数的数字为偶数且数位为奇数的数字为奇数,那么这个数就是好数

思路

  1. 首先确认所有的条件都必须要满足,奇对奇,偶对偶
  2. 这个很显然就是需要枚举,因为1------n这个范围内的数字都需要判断
  3. 那么就可以用bool函数判断每一个数字是否是好数,在主函数里面就负责把每个函数都过一遍
  4. 那就可以用一个数来专门去判断数位,从个位数开始判断,然后设置当这个数位为奇数时这个数是否是奇数的判断,判断完之后,数位依次递增,这个数依次减小因为需要把这个数的末尾数给剪掉,那么就欧克了

坑点

  1. 脑子没转过来,123的个位数是3不是1hhh该睡了,其他没有难点了
  2. 主要是复习了枚举和bool函数

算法一:枚举和bool

实现步骤
  1. bool判断,如果不满足条件直接return false,都满足直接return true

  2. 再加一个内部优化,当这个函数的末尾数是偶数可以直接pass,这样就不需要bool判断了

  3. x

代码
cpp 复制代码
 #include<iostream>
using namespace std;
bool check(int x){
	int cnt=1;//记数位
	while(x){
		int b=x%10;
		if(cnt%2==1)//是奇数  {
			if(b%2!=1) return false;
			}
		else if(b%2!=0)	return false;
	
		cnt++;
		x/=10;
	}
	return true;
}
int main(){
	long long int n;
	int ans=0; 
	cin>>n;
	for(int i=1;i<=n;i++){
		if(i%10%2==0){
			continue;
		}
		if(check(i)){
			ans++;
		}
	}
	cout<<ans;
	return 0;
} 

 

总结

真的很简单的一道题,但是居然因为觉得最后一个数字是最大的那个数位上的数,纠结了两个小时,好无语啊,以后写还是需要拿笔去写,脑子清楚一点,拜托。。

相关推荐
追随者永远是胜利者2 小时前
(LeetCode-Hot100)4. 寻找两个正序数组的中位数
java·算法·leetcode·职场和发展·go
我命由我123453 小时前
Photoshop - Photoshop 工具栏(61)切片工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
我命由我123454 小时前
Photoshop - Photoshop 工具栏(62)切片选择工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
追随者永远是胜利者4 小时前
(LeetCode-Hot100)5. 最长回文子串
java·算法·leetcode·职场和发展·go
小李独爱秋5 小时前
模拟面试:什么是容器技术,Docker是什么?
运维·docker·容器·面试·职场和发展
闻缺陷则喜何志丹5 小时前
【分组背包】P12316 [蓝桥杯 2024 国 C] 循环位运算|普及+
c++·算法·蓝桥杯·洛谷·分组背包
YGGP5 小时前
【Golang】LeetCode 41. 缺失的第一个正数
算法·leetcode·职场和发展
追随者永远是胜利者6 小时前
(LeetCode-Hot100)17. 电话号码的字母组合
java·算法·leetcode·职场和发展·go
零售ERP菜鸟7 小时前
数据驱动:从经验主义的“后视镜”到科学决策的“导航仪”
大数据·人工智能·职场和发展·创业创新·学习方法·业界资讯
_OP_CHEN7 小时前
【算法提高篇】(三)线段树之维护更多的信息:从基础到进阶的灵活运用
算法·蓝桥杯·线段树·c/c++·区间查询·acm/icpc·信息维护