免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1890 | 回复: 9
打印 上一主题 下一主题

出道题目给大家玩玩 , [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-18 15:12 |只看该作者 |倒序浏览
一个数组 a[n],数组长度为n, 已知  n = 2^32.  
数值为 1,2, 3.....2^32.

a[0] =1
a[1] =2
.....
   

随机乱序整个数组,  取出乱序后数组的最后的一个数字。



1 找出这个数字, 求算法


2 取掉最后的2个数字, 求算法

[ 本帖最后由 benjiam 于 2009-7-18 22:15 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-07-18 21:12 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
3 [报告]
发表于 2009-07-18 21:29 |只看该作者
没看懂题,数组长度为N, 数值为 1-2^32.
到底是哪个数值,全部的?

论坛徽章:
0
4 [报告]
发表于 2009-07-18 21:30 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
5 [报告]
发表于 2009-07-19 01:05 |只看该作者
没看懂问题~~~~

论坛徽章:
0
6 [报告]
发表于 2009-07-19 02:36 |只看该作者
原帖由 benjiam 于 2009-7-17 23:12 发表
一个数组 a[n],数组长度为n, 已知  n = 2^32.  
数值为 1,2, 3.....2^32.

a[0] =1
a[1] =2
.....
   

随机乱序整个数组,  取出乱序后数组的最后的一个数字。



1 找出这个数字, 求算法 ...


所有剩下的数字异或起来就是缺少的那个数字。因为要是一个都不缺的话,全异或起来是0.

少两个的话,求剩下的数的平方和X,全加起来得到Y。然后求解方程(设缺少的两个数是a和b):
a*a + b*b = n(n+1)(2n+1)/6 - X
a + b = n(n+1)/2 - Y
可能具体公式数字有点出入,自己考证一下就行。

论坛徽章:
1
寅虎
日期:2014-11-30 21:25:54
7 [报告]
发表于 2009-07-19 05:09 |只看该作者

回复 #6 emacsnw 的帖子

厉害 原来是这个意思  第一题全部异或起来我算是2^32啊?

论坛徽章:
0
8 [报告]
发表于 2009-07-19 16:03 |只看该作者
原帖由 emacsnw 于 2009-7-19 02:36 发表


所有剩下的数字异或起来就是缺少的那个数字。因为要是一个都不缺的话,全异或起来是0.

少两个的话,求剩下的数的平方和X,全加起来得到Y。然后求解方程(设缺少的两个数是a和b):
a*a + b*b = n(n+1)( ...

不是很认同LS的方法,那样是找不出那个数的

我提供一种思路,把原来的数组保存,然后每个都减去现在的数组,组成一个新的数组,最后加起来的值就是缺少的值

论坛徽章:
0
9 [报告]
发表于 2009-07-19 20:15 |只看该作者
嘿嘿,

论坛徽章:
1
双子座
日期:2015-01-04 14:25:06
10 [报告]
发表于 2009-07-20 13:36 |只看该作者
设乱序后的数组为a1
1、设取出的数字为x
x=n*(1+2^32)/2 - a1[0] - a1[1] - ... - a[n-2]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP