基本算法思维——密码试探
emmmmmm,使用的是别人的代码!
问题:
小赛是一名幸运的程序员。
虽然他成功帮助小朋友以最快时间夺回了狼堡,但是面试官却打算和他说拜拜了。
理由是——游戏天赋太高,有不务正业、走火入魔的倾向QAQ……
尽管小赛很不能接受这个理由,可是却只能心灰意冷地吃下这个结果。
然而,在他即将走出门的时候,面试官给了幸运的小赛一个最后的机会。
原来,面试官的手机被他调皮的儿子小明用一个数字作为密码锁上了。
小明只记得这个数字的十进制范围是l~r,且这个数的二进制表示中恰有m个1,却不记得确切的数字了。
面试官可急坏了。这才有了小赛一个将功赎过的机会。
他想要让小赛算出,他最坏情况下,要试多少次密码才能确保打开手机呢?
请输出这个次数。
分析:穷举查找
(1)分析范围内的数的二进制,检查是否恰好包含m个1
code:
1 import java.util.Scanner; 2 3 public class Main { 4 5 public static void main(String[] args){ 6 7 Scanner in = new Scanner(System.in); 8 int l = 0,r = 0,m = 0; 9 int count = 0; 10 if (in.hasNext()) { 11 l = in.nextInt(); 12 r = in.nextInt(); 13 m = in.nextInt(); 14 } 15 if (l > r) 16 count = -1; 17 //穷举检测:检测该数字内是否恰好包含m个1 18 for (int i = l; i <= r; i++) { 19 if (checkOne(i,m)) 20 count++; //满足则记录 21 //System.out.println("count:" + count); 22 } 23 if (count == 0) 24 count = -1; 25 System.out.println("" + count); 26 } 27 28 //检查一个整型数字的二进制是否刚好包含m个1 29 public static boolean checkOne(int n, int m){ 30 while (n != 0) { 31 if ((n&1) == 1) //检查最低位是否为1 32 m--; 33 n = n >> 1; //无符号右移 34 } 35 //System.out.println("m:" + m); 36 if (m == 0) 37 return true; 38 else 39 return false; 40 } 41 42 }