最后几个题有点难度,在这里说一下:

永成科技C++笔试题
2013-11-19

1.将1亿以内的质数存到一个超级大的数组中,用算法如何实现?
使用"筛法"求解1亿以内的质数的程序的思路:
先动态分配1亿个bit(总计12500000字节),用字节中的每一位代表每一个整数,首先将代表奇数的那些bit位置1,也就是代表偶数(合数)的位,接着再进一步从这些奇数位中筛掉合数.
筛掉合数的方法是,先从100000000(1亿)的开方10000范围内的质数i(3,5,7,11,13,17,19,23,29)开始,去找它在1亿内的奇数倍数i*i,i*i+2i,i*i+4i,...,这里
没有i*i+i是因为它可以写成(i+1)i是2的倍数,已经被过滤掉,将代表这些合数的bit位置0,
那么最后剩下的bit为1的那些bit,就是代表质数的,统计出它们的个数就可以了.

这样做的原理是,基于如下的事实:
(1)任意连续的6个数中,就只会测试2个而已,以6n, 6n+1, 6n+2, 6n+3, 6n+4, 6n+5为例,只需测试6n+1和6n+5, 工作量减少到1/3
(2)判断一个数i是否是素数的话,只需要测试2->sqrt(i)之间的质数就可以了
理由如下:
按素数的定义,也就是只有 1 与本身可以整除,所以可以用 2→i-1 去除 i,如果都除不尽,i 就是素数。观点对,但却与上一点一样的笨拙。当 i>2 时,有哪一个数可以被 i-1 除尽的?没有!为什么?如果 i 不是质数,那么 i=a×b,此地 a 与 b 既不是 i 又不是 1;正因为 a>1,a 至少为 2,因此 b 最多也是 i/2 而已,去除 i 的数用不着是 2→i-1,而用 2→i/2 就可以了。不但如此,因为 i=a×b,a 与 b 不能大于 sqrt(i),为什么呢?如果 a>sqrt(i),b>sqrt(i),于是 a×b > sqrt(i)*sqrt(i) = i,因此就都不能整除i了。如果i不是质数,它的因子最大就是 sqrt(i);换言之,用 2→sqrt(i)去检验就行了
但是,用 2→sqrt(i) 去检验也是浪费。就像前面一样,2 除不尽,2 的倍数也除不尽;同理,3 除不尽,3 的倍数也除不尽……最理想的方法就是用质数去除i。
如果只检查 6n+1 和 6n+5 ?不难发现,它们的距离是4、2、4、2……所以,可以先定义一个变量 gab=4,然后 gab=6-gab;
(3)不能用开方而应该用平方
比较是不能用 sqrt(i),因为它不精确。举个例子,i=121,在数学上,sqrt(i) 自然是 11,但计算机里的结果可能是 10.9999999,于是去除的数就是 2、3、5、7,而不含 11,因此 121 就变成质数了。解决这个问题的方法很简单,不要用开方,用平方即可。例如,如果 p*p<=i,则就用 p 去除 i。而且它的效率比开方高。

为此需要先将2,3,5,7,11,13这样的质数先定位到32bit长度的整数内,这个整数的四字节中的每个字节是10101010,将这个质数放到32bit中的唯一一个bit位上面.
最后计算的结果是5761455个素数,而且程序用时9.375秒

下面是一个老外提供的实现代码,但是我们还有比这个更高效的处理:

//Platform: Ubuntu 12.04.3 64bit
//gcc -std=c99 -g primer_demo.c -o primer_demo
#include <stdio.h>
#include <memory.h>
#include <stdlib.h>
#include <time.h>int count(unsigned int a)  //统计每个整数中的非0位个数,也就是素数的个数(素数没被筛掉,相对应位为1)
{int sum = 0;for (unsigned int x=a; x; x>>=1)  //x不断作右移运算{if (x & 1)  //x与1作与运算sum++;}return sum;
}void sieve(unsigned int* p)  //筛选法求1亿以内素数
{
//    for(int i=2;i<=10000;i++)
//    for (int i=3; i<=10000; i+=2)   //只筛选奇数显然快于原算法for(int istep=4,i=3; i < 10000 ;i+=(istep^0x6))  //进一步优化,%6余1和5时才可能是素数,即只检查交替相隔2和4的数{if (p[i/32] & (1<<i%32))  //第i个整数对应的32位整数序位为i/32,对应无符号整数的第i%32位,该语句判断p[i]是否为1{  //上面的1<<i%32中,%的优先级高,所以先算出i在无符号整数中在哪一位,然后将1左移这么多位
//          for (int j=i*i; j<100000000; j+=i)for(int j=i*i ;  j<100000000; j+=i*2)   //改进版,每次跳跃检查,j+i已经被2筛除了,每次应检查j+2*i{p[j/32] &= ~(1<<j%32);  //第j个整数置为合数,即是将相应位置0}}}
}int main()
{clock_t start = clock();unsigned int* p = (unsigned int*) malloc(12500000);  //向堆空间申请一亿位(12500000字节*8)if (!p){printf("Not enough memory.\n");return 1;}
//    memset(p,255,12500000);  //将一亿位全置为1(无符号整数为255)memset(p,170,12500000);     //将一亿位中的奇数位索引全置为1(索引从0开始,无符号整数为170)sieve(p);  //对应非素数位全清0int num = 0;   //  整数1对应位置为1,整数2对应位置为0,正好计数的时候抵消了,所以NUM初始化为0。for (int i=0; i<12500000/4; i++){num += count(p[i]);}free(p);printf("within 100,000,000 primers total counter:%d, total time was %7.3f in second\n",num,(double)(clock()-start)/CLOCKS_PER_SEC);return 0;
}

2.二叉树求值?
要求使用递归和循环这两种方法实现.

3.设计简单的文本编辑器,写出架构设计及思路?

永成科技C++笔试题相关推荐

  1. 石家庄盛鼎科技有限公司笔试题

    石家庄盛鼎科技有限公司笔试题 工作任务分配及能力考核系统V1.4 1. 系统要求 使用框架Struts 2+Spring+Hibernate [+Sitemesh][+FreeMarker]  ...

  2. 亚信科技java笔试题答案_亚信科技笔试题

    搜来的,嘿嘿 亚信科技笔试题 1. interface 和 abstract 的区别? abstract 可不可以继承 interface, interface 可不可以继承 interface? 2 ...

  3. 发现一张三年前飔拓科技的笔试题,清一色的数据结构和算法。

    发现一张三年前飔拓科技(举办光谷国际人工智能产业论坛)的笔试题,我之前也是有印象的,,你细看可以发现就是清一色的数据结构和算法题目.

  4. 复临科技软件测试笔试题-精品

    又又又是高新园C出口,中科大厦.12点多从智慧广场那边回来,在中国开发研究院旁边的快餐店吃了个快餐.太贵了,只点了2个菜,青菜和一块猪排.15.6蚊.吃饭期间有个普度科技的软件测试工程师职位的电话打过 ...

  5. 南京软世通科技11-19笔试题

    笔试题 java基础知识 java基础知识2 java中实现多态的机制是什么 重载(overload)和重写(override) 如果一个子类继承了一个父类,子类中拥有和父类相同方法名称,返回值,参数 ...

  6. 威富通科技软件测试笔试题

    刚从高新园回来,记录一下去威富通面试的过程. 26楼,进门登记后,前台小姐姐(穿着我双十一下单的阿迪达斯!...(⊙o⊙)-)会给一份软件测试笔试题.主要内容有: 一.软件测试理论,像什么软件测试流程 ...

  7. 北京云端微服科技2017笔试题

    声明:答案并非标准答案,只是自己做的而已,仅供参考 一.选择题 1.String str; 以下哪种写法较为合理(   )  (4个答案都对,答案不确定) A str.equals("ydw ...

  8. ArrayList、LinkedList哪家强,据说90,亚信科技Java笔试题

    结果:ArrayList----time:2493 public static void main(String[] args) { List list = new ArrayList<> ...

  9. 创林科技算法笔试题其二

    课堂交流加密解密问题 这个问题有点意思, 难度适中, 是类似加密与解密的算法. 题目 李雷和韩梅梅坐前后排,上课想说话怕被老师发现,所以改为传小纸条.为了不被老师发现他们纸条上说的是啥,他们约定了如下 ...

最新文章

  1. LeetCode简单题之移动零
  2. 中科院自动化所17篇CVPR 2022 论文新作速览!
  3. hashcode()和hash()
  4. JavaScript中为什么string可以拥有方法?
  5. android自定义url协议,Android自定义URL方案…?
  6. nextcloud+nginx+mysql_nextcloud网盘搭建:Ubuntu18.04+Nginx+Mysql
  7. 介绍两种常见软件开发模式:“敏捷”和“瀑布”
  8. nginx跨域配置、使用,docker部署nginx全流程(实测简单完整无坑)
  9. 网络存储磁带库术语解释
  10. matlab 图例自定义,matlab实现自定义曲线图以及图例
  11. 【JavaEE】电商秒杀项目·第2章·基础项目搭建
  12. 常用设计模式——装饰者模式
  13. String比较字符串方法
  14. 什么是token?Android中token的使用讲解
  15. 自学了半个月感觉一点也没学会Python,Python真的有这么难学吗
  16. Linux入侵排查脚本
  17. vue v-html事件失效?自定义指令有何不可
  18. JAVA笔记- JAVA对象数组的遍历与使用详解
  19. 第一个java程序书_Java入门(4) 第一个Java程序
  20. html301重定向域名后缀,网站出现死链了内页301重定向帮你解决

热门文章

  1. PyTorch 笔记(07)— Tensor 的归并运算(torch.mean、sum、median、mode、norm、dist、std、var、cumsum、cumprod)
  2. 判断一个字符串中出现次数最多的字符
  3. 【BZOJ2434】[NOI2011]阿狸的打字机 AC自动机+DFS序+树状数组
  4. Android环境搭建和Android HelloWorld—Android开发环境搭建
  5. senfile函数实例的运行过程截图
  6. leetcode:Search in Rotated Sorted Array
  7. oracle 分区使用情况,Oracle Hash分区的使用总结
  8. C语言程序设计 细节总结(第10-11章 文件、预处理命令)
  9. C语言下标要求数组或指针,c语言改错 error C2109: 下标要求数组或指针类型怎么改?...
  10. inno setup插件可选安装代码_代码检测工具(sonar docker方式安装)