zoukankan      html  css  js  c++  java
  • 基本算法思维——密码试探

    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 }
  • 相关阅读:
    C# 2.0 中Iterators的改进与实现原理浅析
    C#窗口关闭时最小化到托盘
    设计模式有趣解释
    序列化学习
    线程学习
    正则表达式
    .net内存回收与Dispose﹐Close﹐Finalize方法 [摘]
    5.匿名函数lambda
    2dns服务器解析创建
    2.ftp匿名
  • 原文地址:https://www.cnblogs.com/dream-flying/p/12803032.html
Copyright © 2011-2022 走看看