声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1276|回复: 5

[编程技巧] 两个集合之差的问题

[复制链接]
发表于 2007-5-13 20:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
我想请教一下,比如有一个长950的向量,
值是从1到1000之间的整数,互不重复
怎样求出1到1000之间其余的50个数字呢
多谢各位了啊:@)

[ 本帖最后由 eight 于 2007-5-14 09:56 编辑 ]
回复
分享到:

使用道具 举报

发表于 2007-5-13 20:33 | 显示全部楼层
这个问题有点意思,我试着写了下:

M=1000;
m=1:M;

N=950;
n=floor(randn(1,N)*(N-1))+1;

mt=zeros(size(m));
mt(n)=1;

result=m(find(mt==0));

这里的950个整数可能有重复,但重复的时候是对的,对于不重复的情况肯定也是对的。
呵呵,看看大家有什么更有效的方法

评分

1

查看全部评分

发表于 2007-5-14 09:53 | 显示全部楼层
我也写了一个:
  1. A = randperm(1000);
  2. B = setdiff([1:1000], A(1:950));
复制代码

评分

1

查看全部评分

发表于 2007-5-14 10:57 | 显示全部楼层
发表于 2007-5-14 11:18 | 显示全部楼层
偶也来一个:
A = randperm(1000);
B=1:1000;
C=B(~ismember(B,A(1:950)))

评分

1

查看全部评分

 楼主| 发表于 2007-5-14 16:34 | 显示全部楼层
哈哈,多谢各位的回答,
很有帮助啊,大大节省了存储空间
发现我都不知道这些函数,最初是将这950个数挨个与那1000个数比较,
相同的话设置标志位,好多次循环啊,:@L
呵呵,谢谢,俺会好好学习的:loveliness:
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-11-12 12:30 , Processed in 0.065299 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表