c#“小”程序:

using System;

using System.Collections.Generic;

using System.Text;

namespace FindTheNumber

{
  class Program
  {
    static void Main(string[] args)
    {
      int [] rg =
          {2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,
           20,21,22,23,24,25,26,27,28,29,30,31};
      for (Int64 i = 1; i < Int64.MaxValue; i++)
      {
        int hit = 0;
        int hit1 = -1;
        int hit2 = -1;
        for (int j = 0; (j < rg.Length) && (hit <=2) ; j++)
        {
          if ((i % rg[j]) != 0)
          {
            hit++;
            if (hit == 1)
            {
              hit1 = j;
            }
            else if (hit == 2)
            {
              hit2 = j;
            }
            else
              break;
          }

        }
        if ((hit == 2)&& (hit1+1==hit2))
        {
          Console.WriteLine("found {0}", i);
        }
      }
    }
  }
}

问题:

问题1:这个程序要找的是符合什么条件的数?

问题2:这样的数存在么?符合这一条件的最小的数是什么?

问题3:在电脑上运行这一程序,你估计多长时间才能输出第一个结果?时间精确到分钟(电脑:单核CPU 4.0G Hz,内存和硬盘等资源充足)。

问题4:在多核电脑上如何提高这一程序的运行效率?

阅读之感:

乍一看!啥!!c#,一门新的编程语言,这也太高看我了吧!!!

仔细看!噢!!问题,也不是远离我的代码,咱学过c、c++、labview(这和题目没啥大关系)!!!

接下来的研究看!

先是初始化了一个从2到31的30个元素的整型数组rg,然后是两个嵌套的for循环,外层循环从1一直到int64即2^63-1,里有一个if判断语句来输出结果;内层循环从0到rg.Length) 并且 (hit <=2),里面也有一个判断。

咱开始手动跟踪程序的流程,具体如下:

i=1

j = 0     hit=1     hit1=0    hit2=-1
j = 1     hit=2     hit1=0    hit2=1
j = 2     hit=3     hit1=0    hit2=1    跳出内层循环
hit!=2无输出

i=2

j = 0     hit=0    hit1=-1   hit2=-1
j = 1     hit=1    hit1=1    hit2=-1
j = 2     hit=2    hit1=1    hit2=2
j = 3     hit=3    hit1=1    hit2=2     跳出内层循环
hit!=2无输出

i=3

j = 0     hit=1    hit1=0    hit2=-1
j = 1     hit=1    hit1=0    hit2=-1
j = 2     hit=2    hit1=0    hit2=2
j = 3     hit=3    hit1=0    hit2=2     跳出内层循环
hit!=2无输出

i=4

j = 0     hit=0    hit1=-1   hit2=-1
j = 1     hit=1    hit1=1    hit2=-1
j = 2     hit=1    hit1=1    hit2=-1
j = 3     hit=2    hit1=1    hit2=3
j = 4     hit=3    hit1=1    hit2=3     跳出内层循环
hit!=2无输出

.

.

.

根据几次跟踪流程,不难看出要输出的数必须要满足条件(hit == 2)&& (hit1+1==hit2),从hit1+1==hit2可以在整型数组rg内有两个连续的数,hit==2表明不能被这两个连续的数整除,而rg内的其他数都能整除。。

所以问题1的答案就出来了:1~(2^63-1)中所有的 不能被 2~31 中某相邻的两个数整除,但可以被其余28个数整除的数。

问题2的答案:

在问题1里我们知道所求数不能被 2~31 中某相邻的两个数整除,但可以被其余28个数整除,,其实这个范围还是大,,不能被一个数整除一定不能被这个数的倍数整除,,故而可以将范围缩小到16~31,,然后就没然后了........

问题3的答案:

windows系统自带的计算器显示2^63-1 = 9,223,372,036,854,775,807,粗略的估计为9*10^18,故外层循环有9*10^18次,里层循环30次,故进行270*10^18次循环,假如一个机器周期执行一次循环(实际上一次循环所需时间大于一个机器周期),因为题目提供的频率为4.0G Hz,故一个机器周期为0.25*10^(-9)s;所有循环进行完大约需耗时67.5*10^9s,约合10^9分钟。。。。。一天才1440分钟,,,,要等好长好长的时间

问题4的答案:首先肯定是可以运用多核技术,将程序分成多线程,并发执行;其次在于算法的优化。。。。。

阅读c#程序——回答问题的更多相关文章

  1. 阅读程序 回答问题——FindTheNumber

    阅读程序 回答问题——FindTheNumber 阅读下面程序,请回答如下问题:问题1:这个程序要找的是符合什么条件的数?问题2:这样的数存在么?符合这一条件的最小的数是什么?问题3:在电脑上运行这一 ...

  2. 微信小程序-阅读小程序demo

    今天和朋友聊天说到小程序,然后看在看书,然后我们就弄了个小读书的demo,然后现在分享一下. 一.先来上图: 二.然后下面是详细的说明  首先先说下边的tabBar,项目采用json格式的数据配置,不 ...

  3. 阅读verilog程序总结

    1.写程序先直接写出时钟信号 //-----------------产生串行时钟scl,为输入时钟的二分频--------- always@(negedge clk)//二分频表示频率小了,周期大了 ...

  4. Java阅读word程序说明文件

    完成office文件操作可以帮助apache.poi包(我用poi-3.10-FINAL),导入对应的jar包(最好所有导入) 以下的程序演示了一些操作word的过程,具体的函数功能能够查看此包的官方 ...

  5. C#代码分析--阅读程序,回答问题

    阅读下面程序,请回答如下问题: 问题1:这个程序要找的是符合什么条件的数? 问题2:这样的数存在么?符合这一条件的最小的数是什么? 问题3:在电脑上运行这一程序,你估计多长时间才能输出第一个结果?时间 ...

  6. c#程序阅读分析

    using System; using System.Collections.Generic; using System.Text; namespace FindTheNumber { class P ...

  7. Uoj 73 未来程序

    Uoj 73 未来程序 神仙提答. Subtask 1 仔细阅读,发现是要计算 \(a*b\ \%\ c\).用龟速乘或者 \(python\) 直接算. Subtask 2 仔细阅读并手算一下,发现 ...

  8. 科技爱好者周刊(第 174 期):全能程序员 vs 特长程序员

    这里记录每周值得分享的科技内容,周五发布. 本杂志开源(GitHub: ruanyf/weekly),欢迎提交 issue,投稿或推荐科技内容. 周刊讨论区的帖子<谁在招人?>,提供大量程 ...

  9. 对于前端,「微信小程序」其实不美好

    微信小程序开放公测了,9月底我曾经写过一篇 「微信小程序」来了,其中最后一句:"谢天谢地,我居然还是个前端". 这种火爆的新事物总是令人激动,感谢这个时代. 但是,当我真作为开发者 ...

随机推荐

  1. 矩阵dp

    矩阵dp 这里是矩阵dp,不是矩阵乘法优化dp. 矩阵上的dp好像也没什么特殊的?大概有一个套路就是从上向下,从左向右进行dp吧. 首先第一道题好像不是矩阵dp... 1005 矩阵取数游戏:http ...

  2. php大流量高并发解决方案

    一.硬件 提升硬件,影响因素有: 带宽-硬盘读写速度-内存大小-cpu处理速度   二.软件 反向代理负载均衡 mysql : 1.优化你的sql和索引 2.加缓存,memcached,redis 3 ...

  3. HTTP协议请求方式: 中GET、POST和HEAD的介绍_孤帆一叶

    HTTP协议中GET.POST和HEAD的介绍 2008-05-10 14:15 GET: 请求指定的页面信息,并返回实体主体.HEAD: 只请求页面的首部.POST: 请求服务器接受所指定的文档作为 ...

  4. JVM内存管理及GC机制

    一.概述 Java GC(Garbage Collection,垃圾收集,垃圾回收)机制,是Java与C++/C的主要区别之一,作为Java开发者,一般不需要专门编写内存回收和垃圾清理代码,对内存泄露 ...

  5. haproxy安装及日志配置

    1.yum安装 yum install haproxy -y 2.配置文件修改,经典配置 vim /etc/haproxy/haproxy.cfg #------------------------- ...

  6. 通过SSH秘钥登录线上MySQL数据库(基于Navicat)

    前言 生产环境的数据库往往需要经过严格的安全限制,所以禁用密码登录,使用秘钥的方式是一种相对安全的登录方式. 原理: 角色: 主机A:其他主机,有访问线上数据库的权限 主机B:线上数据库的主机 主机C ...

  7. C++之new和delete操作符

    在C语言中的动态分配和释放内存的函数是malloc calloc 和 free , 而在C++中要用 new new[] delete delete[] 来申请动态空间和释放空间. 注意:的是new. ...

  8. scapy学习笔记(1)

    转载请注明:小五义 http://www.cnblogs.com/xiaowuyi scapy是python写的一个功能强大的交互式数据包处理程序,可用来发送.嗅探.解析和伪造网络数据包,常常被用到网 ...

  9. 开启路由转发 - route add -net 0.0.0.0 netmask 0.0.0.0 gateway 192.168.0.131 window tracert 追踪路由

    1.登录方式内网访问172.28.101.0/19网段的方法:在192.168.1.0/24网段的上网机器上,或在自己的操作机上加个192.168.1.0网段的ip,注意不要跟别人设置的冲突了,并添加 ...

  10. Flutter - JSON to Dart,一个json转dart实体的网站

    如你所见,一个json转dart实体的网站,https://javiercbk.github.io/json_to_dart/