解密


解密

题目详情:

小强是一名学生, 同时他也是一个黑客。 考试结束后不久,他惊讶的发现自己的高等数学科目居然挂了,于是他果断入侵了学校教务部网站。在入侵的过程中,他发现了与成绩相关的内容是一个加密文件,这个文件由 n 个数构成,经过分析,这个加密文件的密钥为这 n 个数中二进制位数 1 最少的数。但由于数比较多,小强 希望你能帮他得到密钥,好在成绩公布之前将成绩改过来。

输入描述:

输入由多组数据构成,每组数据第一行为一个数 n(1<=n<=10^5),表示数的数量,第二行 n 个整数表示文件中的每个数(1<=每个数<=10^9)。以文件结尾。

输出描述:

对于每组数据输出一行,先输出数据组数,再输出二进制中含 1 最少的数,如果有多个数符合条件,输出最小的那个。



答题说明:

输入样例:

5

3 2 4 5 6

输出样例:

Case 1: 2



import java.util.Scanner;
import java.util.Vector;

public class EFS {
 public static void main(String args[]) {
  EFS efs = new EFS();
  efs.printEFS();
  efs.printSolve();
 }

 private Vector<Object> groups;
 
 EFS() {
  groups = new Vector<Object>();
  System.out.println("请输入(以0结束):");
  Scanner input = new Scanner(System.in);
  int n = input.nextInt();
  while(n != 0) {
   int[] group = new int[n];
      for(int i = 0; i < n; i++)
       group[i] = input.nextInt();
      groups.add(group);
      n = input.nextInt();
  }
  input.close();
 }

 void printEFS() {
  for(int i = 0; i < groups.size(); i++) {
   int[] group = (int[]) groups.elementAt(i);
   for(int j = 0; j < group.length; j++)
    System.out.print(group[j] + " ");
   System.out.println();
  }
 }
 
 Vector<Integer> solve() {
  Vector<Integer> v = new Vector<Integer>();
  for(int i = 0; i < groups.size(); i++) {
   int[] group = (int[]) groups.elementAt(i);
   int pass = group[0];
   int count = numberOfOneIn(group[0]);
   
   for(int j = 1; j < group.length; j++) {
    int temp_count = numberOfOneIn(group[j]);
    if(temp_count < count || temp_count == count && group[j] < pass) {
     pass = group[j];
     count = temp_count;
    }
   }
   v.add(pass);
  }
  return v;
 }
 
 
 void printSolve() {
  Vector<Integer> v = solve();
  for(int i = 0; i < groups.size(); i++)
   System.out.println("Case " + (i + 1) + ": " + v.elementAt(i));
 }
 
 
 static int numberOfOneIn(int num) {
  int count = 0;
  while(num != 0) {
   if(num % 2 != 0)
    count++;
   num >>= 1;
  }
  return count;
 }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值