zoukankan      html  css  js  c++  java
  • 认真对待每一道算法题 之 找明星问题

    n个人中只有一个明星,明星不认识其他所有的人,而其他人都认识明星,不是明星的人可能认识也可能不认识。你每次只可以问一个人是否认识另一个人这样的问题,问最少问多少次可以找出明星。

    做法1:

    将所有人站队,按照顺序(假如编号分别为1、2、3.。n),首先问1,2互相认识,有四种情况出现:

    (1)1 认识 2,2不认识1, 认识别人的肯定不是明星,排除1;

    (2)1 不认识2,2认识1, 根据(1)的道理,同样可以排除2;

    (3)1与2 互相认识,可以断定,两个人都不是明星,随机删除一个就好;

    (4)1与2 相互认识,同(3),随机删除一个就好;

    接下来,将3号与之前1与2比较之后的剩余者进行同样方式的比较,依次类推,最后还剩余的那个就是明星了;

  • 相关阅读:
    JVM结构
    redis缓存淘汰策略
    idea常用快捷键
    Spring常用注解
    redis持久化
    crontab定时调度
    redis五种数据类型
    LVM实验报告
    fdisk以及parted分区实验
    fdisk与parted的区别以及parted为何可分128个区
  • 原文地址:https://www.cnblogs.com/yuhan-TB/p/3856184.html
Copyright © 2011-2022 走看看