文章目录

  • 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)相关推荐

  1. LeetCode 1056. 易混淆数(哈希)

    文章目录 1. 题目 2. 解题 1. 题目 给定一个数字 N,当它满足以下条件的时候返回 true: 原数字旋转 180° 以后可以得到新的数字. 如 0, 1, 6, 8, 9 旋转 180° 以 ...

  2. 编程判断元素归类_编程练习-判断是否为易混淆数

    题目来源:LeetCode 给定一个数字 N,当它满足以下条件的时候返回 true: 把原数字旋转180°以后得到新的数字. 如 0, 1, 6, 8, 9 旋转 180° 以后,得到了新的数字 0, ...

  3. java 怎么判断1_1.0_1.00是同一个数_编程练习-判断是否为易混淆数

    题目来源:LeetCode 给定一个数字 N,当它满足以下条件的时候返回 true: 把原数字旋转180°以后得到新的数字. 如 0, 1, 6, 8, 9 旋转 180° 以后,得到了新的数字 0, ...

  4. leetcode算法题--丑数 II★

    原题链接:https://leetcode-cn.com/problems/ugly-number-ii/ 三指针 int nthUglyNumber(int n) {int a = 0, b = 0 ...

  5. LeetCode 247. 中心对称数 II(DP)

    文章目录 1. 题目 2. 解题 1. 题目 中心对称数是指一个数字在旋转了 180 度之后看起来依旧相同的数字(或者上下颠倒地看). 找到所有长度为 n 的中心对称数. 示例 : 输入: n = 2 ...

  6. LeetCode 263. 丑数 264. 丑数 II(DP)

    文章目录 1. LeetCode 263. 丑数 解题 2. LeetCode 264. 丑数 II DP解题 1. LeetCode 263. 丑数 编写一个程序判断给定的数是否为丑数. 丑数就是只 ...

  7. leetcode - 264. 丑数 II

    264. 丑数 II -------------------------------------------- 编写一个程序,找出第 n 个丑数. 丑数就是只包含质因数 2, 3, 5 的正整数. 示 ...

  8. 【重点:BFS】LeetCode 407. Trapping Rain Water II

    LeetCode 407. Trapping Rain Water II 博客转载自:http://www.cnblogs.com/grandyang/p/5928987.html [太难了,被智商碾 ...

  9. leetcode每日一题1609. 奇偶树 圣诞节你做奇偶数了没 BFS套模板一遍过

    本文目录 leetcode每日一题1609. 奇偶树 圣诞节你做奇偶数了没 BFS套模板一遍过~ 写在前面 题目 示例 提示 思路 代码实现 执行结果 写在最后 leetcode每日一题1609. 奇 ...

最新文章

  1. Linux内核源码结构
  2. OpenCV 腐蚀和膨胀
  3. Yii2 的小贴士用法
  4. 并发队列-无界非阻塞队列 ConcurrentLinkedQueue 原理探究
  5. 计算器用户界面与业务逻辑的分离
  6. shell 脚本安装Tomcat和java
  7. 替换Webbrowser默认的弹出菜单
  8. centos桥接模式怎么联网_Parallels Desktop 16教程:PD16虚拟机共享网络和桥接网络设置方法...
  9. ogc是一个非营利性组织_我们的非营利组织如何公开运作以使教育变得容易
  10. 9 10次c语言上机作业答案,第十五次上机作业带答案
  11. GO语言学习之路14
  12. 互联网项目文科程序员的自白
  13. hdu 1788 最小公倍数(这题面。。。)
  14. mac显示和隐藏文件命令
  15. 读书笔记004:《伤寒论》- 手阳明大肠经
  16. MSI (Message Signaled Interrupts)
  17. iOS 图像选取器UIImagePickerController
  18. OCR图片转文字两种python方法实现
  19. 信号采样基本概念 —— 1. 冲激函数
  20. Android高仿网易云音乐播放界面

热门文章

  1. CSS中的块元素,内联元素,内联块元素
  2. mysql 8.0 yum_CentOS8 安装 MySQL8.0(yum)
  3. java metric_java版的Metric工具介绍
  4. int main() 与 void main()
  5. mysql 文件系统规划_Mysql的文件系统规划以及日志配置
  6. 【笔记目录1】【jessetalk 】ASP.NET Core快速入门_学习笔记汇总
  7. servlet中web.xml配置详解
  8. linux —— shell 编程(文本处理)
  9. Angular之简单的登录注册
  10. jQuery 获取页面元素的属性值