猜数字

博客围绕从2到100中抽取两个数字的谜题展开,甲知道两数之和,乙知道两数之积,通过两人对话推理数字。文中给出了用C#编写的程序,包含多个方法用于判断甲、乙是否知道数字,最终输出满足条件的两个数字。

从2到100有99个数字,抽取了两个数字,把这两个数字的和告诉了甲,把他们的乘积告
 诉了乙。以下是这两人的一段对话:
 甲:我不知道是哪两个数字,但我肯定你也不知道。
 乙听了后略一思考,说:我原来也不知道是哪两个数字,但现在我知道了。
 甲听后,先一顿,继而做恍然状,说:哦,我也知道了。
 请问:所抽取的是哪两个数字?

 ///


 /// Guess2 的摘要说明。
 ///
 /// 用J表示甲,Y表示乙。
 /// 先把 JUnknowAndJKnowYUnknow(甲知道而且甲知道乙不知道) 的所有情况放在 arraylist中
 ///
 ///
 public class Guess2
 {
  public Guess2()
  {
   //
   // TODO: 在此处添加构造函数逻辑
   //
   this.InitArrayList();   
   this.Output();
  }

  public static int number = 100;
  private ArrayList arrayJUnknowAndJKnowYUnknow;

  ///


  /// 获得所有满足JUnknowAndJKnowYUnknow的数
  /// 歌德巴赫猜想(大偶数等于二质数之和)虽然没完全证明,
  /// 几十个亿早有人穷举过,如果可能是大偶数,甲不能断定乙肯定不知道。
  ///
  private void InitArrayList()
  {
   this.arrayJUnknowAndJKnowYUnknow = new ArrayList();
   for (int i = 7;   i < 2 * number - 1;   i=i+2)
   {
    if (this.JUnknowAndJKnowYUnknow(i))
     this.arrayJUnknowAndJKnowYUnknow.Add(i);
   }
  }

  public void Print( int x, int y)
  {
   Console.WriteLine ("x = " + x + "   y = "  + y);
  }
  

  ///


  /// 甲不知道数字是什么
  /// 两者的和大于等于7,小于等于197
  ///
  public  bool JUnknow(int sum)
  {
   if (sum <= number*2 - 1 && sum  >= 7)
    return true; 
   return false;
  }
      

  ///


  /// 乙不知道数字是什么。
  /// 有3个以上约数(除1和本身外)
  /// 从2 到该数的平均数之间有两个以上的约数
  ///
  ///   
  public bool YUnknow(int s)
  {    
   int count = 0;
   for (int i = 2;   i <= number && i <= Math.Sqrt(s);   i++)
   {     
    if (s%i == 0 && s/i <= number)  //整除
    {          
      count++;               
    }
    if (count > 1) //表示有两个合数以上
     return true;
  
   }
   return false;
  }

  ///


  /// 甲知道乙不知道,对sum值拆分.列出所有可能。
  ///
  ///
  ///
  public bool JKnowYUnknow (int sum)
  {
   for (int i = 2;   i < sum/2;   i++)
   {
    if (sum - i > 100)
     continue;
    int s = i * (sum - i);
    if (!YUnknow(s))
     return false;
   }
   return true;
  }

  ///


  /// 甲不知道,且甲知道乙不知道。
  ///
  ///
  ///
  public bool JUnknowAndJKnowYUnknow(int sum)
  {
   if (JUnknow (sum) && JKnowYUnknow (sum))
   {
    return true;    
   }
   return false;
  }

  ///


  /// 然后乙知道了
  ///
  ///
  ///
  public bool ThenYKnow (int s)
  {
   int count = 0;
   int x, y;
   //枚举,把积拆分
   for (int i = 2;   i < number && i <= Math.Sqrt(s) ;   i++)
   {         
    if (s%i == 0) 
    {                   
     y = i;
     x = s/i;           
     if (this.arrayJUnknowAndJKnowYUnknow.Contains(x + y)) 
     {
      count ++;
     }
    }
   }
   if (count == 1)
    return true;
   else
    return false;
  }

  ///


  /// 最后甲知道了
  ///
  ///
  ///
  public bool JKnowLast(int sum)
  {
   if (!this.arrayJUnknowAndJKnowYUnknow.Contains(sum))
   {
    return false;
   }
   int count = 0;
   for (int i = 2;   i < sum/2;   i++)
   {
    int s = i * (sum - i);
    if (ThenYKnow(s))
     count++;
   }
   if (count == 1)
    return true;
   return false;
  }

  ///


  /// 打印出结果
  ///
  public void Output()
  {
   Console.WriteLine("---------Guess2---------");
//   foreach (int i in this.arrayJUnknowAndJKnowYUnknow)
//   {
//    Console.WriteLine(i);
//   }

   for (int x = 2;   x <= number;  x++)
   {
    for (int y = 2;   y < x;   y++)
    {     
     if (this.arrayJUnknowAndJKnowYUnknow.Contains(x+y))
     {
      if (this.ThenYKnow(x*y))
       if (this.JKnowLast(x + y))
       {
        this.Print(x, y);
       }
     }
    }
   }
   Console.WriteLine("---------EndofGuess2---------");
  }

  public static void Main()
  {
    new Guess2();
  }
 }

关于 阿里云盘CLI。仿 Linux shell 文件处理命令的阿里云盘命令行客户端,支持JavaScript插件,支持同步备份功能,支持相册批量下载。 特色 多平台支持, 支持 Windows, macOS, linux(x86/x64/arm), android, iOS 等 阿里云盘多用户支持 支持备份盘,资源库无缝切换 下载网盘内文件, 支持多个文件或目录下载, 支持断点续传单文件并行下载。支持软链接(符号链接)文件。 上传本地文件, 支持多个文件或目录上传,支持排除指定文件夹/文件(正则表达式)功能。支持软链接(符号链接)文件。 同步备份功能支持备份本地文件到云盘,备份云盘文件到本地,双向同步备份保持本地文件网盘文件同步。常用于嵌入式或者NAS等设备,支持docker镜像部署。 命令文件路径输入支持Tab键自动补全,路径支持通配符匹配模式 支持JavaScript插件,你可以按照自己的需要定制上传/下载中关键步骤的行为,最大程度满足自己的个性化需求 支持共享相册的相关操作,支持批量下载相册所有普通照片、实况照片文件到本地 支持多用户联合下载功能,对下载速度有极致追求的用户可以尝试使用该选项。详情请查看文档多用户联合下载 如果大家有打算开通阿里云盘VIP会员,可以使用阿里云盘APP扫描下面的优惠推荐码进行开通。 注意:您需要开通【三方应用权益包】,这样使用本程序下载才能加速,否则下载无法提速。 Windows第二步打开aliyunpan命令行程序,任何云盘命令都有类似如下日志输出 如何登出下线客户端 阿里云盘单账户最多只允许同时登录 10 台设备 当出现这个提示:你账号已超出最大登录设备数量,请先下线一台设备,然后重启本应用,才可以继续使用 说明你的账号登录客户端已经超过数量,你需要先登出其他客户端才能继续使用,如下所示
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值