基本算法思维——密码试探

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 }
原文地址:https://www.cnblogs.com/dream-flying/p/12803032.html