LeetCode 1088. 易混淆数 II(回溯/BFS)
文章目录
- 1. 题目
- 2. 解题
- 2.1 回溯
- 2.2 BFS
1. 题目
本题我们会将数字旋转 180° 来生成一个新的数字。
比如 0、1、6、8、9 旋转 180° 以后,我们得到的新数字分别为 0、1、9、8、6。
2、3、4、5、7 旋转 180° 后,是 无法 得到任何数字的。
易混淆数(Confusing Number)指的是一个数字在整体旋转 180° 以后,能够得到一个和原来 不同 的数,且新数字的每一位都应该是有效的。(请注意,旋转后得到的新数字可能大于原数字)
给出正整数 N,请你返回 1 到 N 之间易混淆数字的数量。
示例 1:
输入:20
输出:6
解释:
易混淆数为 [6,9,10,16,18,19]。
6 转换为 9
9 转换为 6
10 转换为 01 也就是 1
16 转换为 91
18 转换为 81
19 转换为 61示例 2:
输入:100
输出:19
解释:
易混淆数为 [6,9,10,16,18,19,60,61,66,68,80,81,86,89,90,91,98,99,100]。提示:
1 <= N <= 10^9
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/confusing-number-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
2. 解题
类似题目:LeetCode 1056. 易混淆数(哈希)
2.1 回溯
class Solution {vector<int> ch = {0,1,6,8,9};int sum = 0;
public:int confusingNumberII(int N) {vector<int> s = {1,6,8,9};for(int i = 0; i < s.size(); i++)dfs(s[i], N);return sum;}void dfs(long long n, int N) {if(n > N)return;if(isok(n))sum++;for(int i = 0; i < ch.size(); i++)dfs(n*10+ch[i], N);}bool isok(long long n){long long num = 0, bit, origin = n;while(n){bit = n%10;n /= 10;if(bit==6) bit = 9;else if(bit== 9) bit = 6;num = num * 10 + bit;}return num != origin;}
};
2.2 BFS
class Solution {public:int confusingNumberII(int N) {queue<long long> q;vector<int> ch = {0,1,6,8,9};q.push(1);q.push(6);q.push(8);q.push(9);int sum = 0;while(!q.empty()){long long n = q.front();q.pop();if(isok(n) && n <= N)sum++;for(int i = 0; i < ch.size(); i++){if(n*10+ch[i] <= N)q.push(n*10+ch[i]);}}return sum;}bool isok(long long n){long long num = 0, bit, origin = n;while(n){bit = n%10;n /= 10;if(bit==6) bit = 9;else if(bit== 9) bit = 6;num = num * 10 + bit;}return num != origin;}
};
468 ms 40.2 MB
我的CSDN博客地址 https://michael.blog.csdn.net/
长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
LeetCode 1088. 易混淆数 II(回溯/BFS)相关推荐
- LeetCode 1056. 易混淆数(哈希)
文章目录 1. 题目 2. 解题 1. 题目 给定一个数字 N,当它满足以下条件的时候返回 true: 原数字旋转 180° 以后可以得到新的数字. 如 0, 1, 6, 8, 9 旋转 180° 以 ...
- 编程判断元素归类_编程练习-判断是否为易混淆数
题目来源:LeetCode 给定一个数字 N,当它满足以下条件的时候返回 true: 把原数字旋转180°以后得到新的数字. 如 0, 1, 6, 8, 9 旋转 180° 以后,得到了新的数字 0, ...
- java 怎么判断1_1.0_1.00是同一个数_编程练习-判断是否为易混淆数
题目来源:LeetCode 给定一个数字 N,当它满足以下条件的时候返回 true: 把原数字旋转180°以后得到新的数字. 如 0, 1, 6, 8, 9 旋转 180° 以后,得到了新的数字 0, ...
- leetcode算法题--丑数 II★
原题链接:https://leetcode-cn.com/problems/ugly-number-ii/ 三指针 int nthUglyNumber(int n) {int a = 0, b = 0 ...
- LeetCode 247. 中心对称数 II(DP)
文章目录 1. 题目 2. 解题 1. 题目 中心对称数是指一个数字在旋转了 180 度之后看起来依旧相同的数字(或者上下颠倒地看). 找到所有长度为 n 的中心对称数. 示例 : 输入: n = 2 ...
- LeetCode 263. 丑数 264. 丑数 II(DP)
文章目录 1. LeetCode 263. 丑数 解题 2. LeetCode 264. 丑数 II DP解题 1. LeetCode 263. 丑数 编写一个程序判断给定的数是否为丑数. 丑数就是只 ...
- leetcode - 264. 丑数 II
264. 丑数 II -------------------------------------------- 编写一个程序,找出第 n 个丑数. 丑数就是只包含质因数 2, 3, 5 的正整数. 示 ...
- 【重点:BFS】LeetCode 407. Trapping Rain Water II
LeetCode 407. Trapping Rain Water II 博客转载自:http://www.cnblogs.com/grandyang/p/5928987.html [太难了,被智商碾 ...
- leetcode每日一题1609. 奇偶树 圣诞节你做奇偶数了没 BFS套模板一遍过
本文目录 leetcode每日一题1609. 奇偶树 圣诞节你做奇偶数了没 BFS套模板一遍过~ 写在前面 题目 示例 提示 思路 代码实现 执行结果 写在最后 leetcode每日一题1609. 奇 ...
最新文章
- Linux内核源码结构
- OpenCV 腐蚀和膨胀
- Yii2 的小贴士用法
- 并发队列-无界非阻塞队列 ConcurrentLinkedQueue 原理探究
- 计算器用户界面与业务逻辑的分离
- shell 脚本安装Tomcat和java
- 替换Webbrowser默认的弹出菜单
- centos桥接模式怎么联网_Parallels Desktop 16教程:PD16虚拟机共享网络和桥接网络设置方法...
- ogc是一个非营利性组织_我们的非营利组织如何公开运作以使教育变得容易
- 9 10次c语言上机作业答案,第十五次上机作业带答案
- GO语言学习之路14
- 互联网项目文科程序员的自白
- hdu 1788 最小公倍数(这题面。。。)
- mac显示和隐藏文件命令
- 读书笔记004:《伤寒论》- 手阳明大肠经
- MSI (Message Signaled Interrupts)
- iOS 图像选取器UIImagePickerController
- OCR图片转文字两种python方法实现
- 信号采样基本概念 —— 1. 冲激函数
- Android高仿网易云音乐播放界面
热门文章
- CSS中的块元素,内联元素,内联块元素
- mysql 8.0 yum_CentOS8 安装 MySQL8.0(yum)
- java metric_java版的Metric工具介绍
- int main() 与 void main()
- mysql 文件系统规划_Mysql的文件系统规划以及日志配置
- 【笔记目录1】【jessetalk 】ASP.NET Core快速入门_学习笔记汇总
- servlet中web.xml配置详解
- linux —— shell 编程(文本处理)
- Angular之简单的登录注册
- jQuery 获取页面元素的属性值