苏州吴中区郭巷派出所永成科技怎么样

永成科技C++笔试题
编辑:www.fx114.net
本篇文章主要介绍了"永成科技C++笔试题",主要涉及到永成科技C++笔试题方面的内容,对于永成科技C++笔试题感兴趣的同学可以参考一下。
最后几个题有点难度,在这里说一下:
永成科技C++笔试题
1.将1亿以内的质数存到一个超级大的数组中,用算法如何实现?
使用&筛法&求解1亿以内的质数的程序的思路:
先动态分配1亿个bit(总计字节),用字节中的每一位代表每一个整数,首先将代表奇数的那些bit位置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-
(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长度的整数内,这个整数的四字节中的每个字节是,将这个质数放到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&&=1)
//x不断作右移运算
if (x & 1)
//x与1作与运算
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&; j+=i)
for(int j=i*
j&; 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();
//向堆空间申请一亿位(字节*8)
printf(&Not enough memory.\n&);
memset(p,255,);
//将一亿位全置为1(无符号整数为255)
memset(p,170,);
//将一亿位中的奇数位索引全置为1(索引从0开始,无符号整数为170)
//对应非素数位全清0
int num = 0;
整数1对应位置为1,整数2对应位置为0,正好计数的时候抵消了,所以NUM初始化为0。
for (int i=0; i&; i++)
num += count(p[i]);
printf(&within 100,000,000 primers total counter:%d, total time was %7.3f in second\n&,num,(double)(clock()-start)/CLOCKS_PER_SEC);
2.二叉树求值?
要求使用递归和循环这两种方法实现.
3.设计简单的文本编辑器,写出架构设计及思路?
一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家社会集体的和公民的合法权益,不得利用本站制作、复制和传播不法有害信息!
二、互相尊重,对自己的言论和行为负责。
本文标题:
本页链接:精彩文章推荐永成科技发展有限公司--------&&公司简介
永成科技发展有限公司,是营口市知名公司,我们以其他的方式主要经营聚壳糖;高蛋白;保鲜剂。我们有最好的产品和专业的销售及技术团队,我们为客户提供最好的产品、良好的技术支持、健全的售后服务。永成科技发展有限公司办公地址为辽宁 营口市 辽宁省站前区,员工人数有,如果您对我们的产品或服务感兴趣,欢迎您联系我司的朱永光 先生 (经理)了解具体情况。
本页是永成科技发展有限公司在利酷搜网站的黄页介绍页,一切信息均为企业主动开放在互联网,或经工商网站可查。如果您是这家公司的负责人或相关员工,若发现该公司信息有误,请点击【】
如果您喜欢该企业,请您分享该企业网址给您的朋友吧!
永成科技发展有限公司地图
相关企业推荐
免责声明:
以上所展示的永成科技发展有限公司信息由用户自行提供或网络收集,利酷搜不担保永成科技发展有限公司信息的真实性、准确性和合法性。利酷搜不涉及用户间因非本网站担保交易方式的交易而产生的法律关系及法律纠纷,纠纷由您自行协商解决。推荐菜价格是综合大众点评网会员提供信息,按照一定科学算法,由程序自动更新而成;由于菜价的实时性,可能有所误差,给您带来的不便,敬请谅解
(C) dianping.com, All Rights Reserved. 本站发布的所有内容,未经许可,不得转载,详见 。亚泰永成科技发展公司
欢迎你,游客
您的位置 -
- / - 详情
亚泰永成科技发展公司
注册资本无需验资
经营模式生产加工
主要市场南美; 东亚; 东南亚; 中东; 非洲;
所属行业耐火、防火材料;
保温、隔热材料;
隔音、吸声材料;
石灰、石膏;
产品信息石膏板; 石膏粉; 龙骨; 石膏板生产线; 石膏粉生产线;
区位信息 -
相关连接 -
企业标签 -
最后更新 23:41:44
浏览次数205次每周更新
河北华润天龙实业发展有限公司 是一家大型多元化产品的生产厂家。产品主要覆盖建材,建材设备,化工产品及一些其他门类。
建材设备部
可根据客户实际情况制定整套的设备生产设计方案。包括设备工艺流程及厂房建设设计。合理紧凑的设备布局可尽量减少用地。工艺简单,易操作,价格合理,无污染,设备有最高的性价比。
产品有各种石膏板,矿棉板,龙骨等。广泛用与天花,隔墙等室内装饰。产品易裁,易刨,易钉。质轻,防火,防潮,吸声,隔热。绿色板材为您创造绿色健康环境。
网站http://www.cyzd8.com
地址中国北京 1f40 北京市朝阳区 管庄东里一号院内22号楼一楼
电话86-010-
文明上网,理性评论。
您的评分1分(毫无价值)2分(可供参考)3分(有点新意)4分(非常有用)5分(无与伦比)
亚泰永成科技发展公司暂无评论
暂时没有评论,欢迎发布第一条评论。
用心创造价值}

我要回帖

更多关于 苏州吴中区郭巷规划图 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信