免费注册 查看新帖 |

Chinaunix

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

不知道这个问题能不能用位运算解决 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-01-11 18:12 |只看该作者 |正序浏览
假设有 m个 32位整数(各不相同)存放于数组 a[m]中 ,如何用最简单快速的方式生成n个数值不同的整数

论坛徽章:
0
14 [报告]
发表于 2011-01-12 13:37 |只看该作者
最快的方法是:
把a[m]中的数从小到大先排序,然后从最大的数开始,依次+1,凑足n个整数。
或从最小的数开 ...
duoduojl 发表于 2011-01-12 10:18



    挺这个方法{:3_189:}

论坛徽章:
0
13 [报告]
发表于 2011-01-12 10:18 |只看该作者
最快的方法是:
把a[m]中的数从小到大先排序,然后从最大的数开始,依次+1,凑足n个整数。
或从最小的数开始,依次-1,凑足n个整数。

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
12 [报告]
发表于 2011-01-12 08:57 |只看该作者
a[m]排序,j=1,i循环从a[0]+1开始,i != a[j],则记录i,否则i++,j++

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
11 [报告]
发表于 2011-01-11 19:42 |只看该作者
题目是啥意思阿

论坛徽章:
0
10 [报告]
发表于 2011-01-11 19:19 |只看该作者
回复 9# wawxdyy


    不是 用排列或者组合方式 组合a数组中的数字 生成数字  如果生成的数字不超过10位时 可以不考虑重复(这是优点)
   大于10位以上 随机数比较合适  具体得分情况看什么合适

论坛徽章:
0
9 [报告]
发表于 2011-01-11 19:16 |只看该作者
这个用位运算感觉没什么意义了 用排列组合应该更适合点儿吧
wb112200 发表于 2011-01-11 18:59



    你的意思是随机生成一个数,然后挨个和a[m]中的进行比较?

论坛徽章:
0
8 [报告]
发表于 2011-01-11 19:13 |只看该作者
这个首先要确定算法,然后再确定如何用位实现。
m和n谁大?我觉得算法层面先确定后才能确定用什么位运算。
liugang9931706 发表于 2011-01-11 18:49



    m和n谁大无所谓,可以假设都小于100

论坛徽章:
0
7 [报告]
发表于 2011-01-11 19:12 |只看该作者
n个数值不同的整数  这是什么意思?
erlangs 发表于 2011-01-11 18:17



    就是说这n个32位整数的数值各不相同,并且与存放在a[m]的数值也不同

论坛徽章:
0
6 [报告]
发表于 2011-01-11 18:59 |只看该作者
这个用位运算感觉没什么意义了 用排列组合应该更适合点儿吧
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP