试过用循环的方法做,距离判断用的是any,结果运算量指数级增加,算不到1000,有没有办法能够只和最近的几个圆进行距离比较呢?
1条回答 默认 最新
- CSDN专家-Matlab_Fans 2021-07-10 21:03关注
已更新。
tic X = []; Y = []; n = 0; while n < 1000 r = rand * (750-5); theta = rand * 2*pi; x0 = r*cos(theta); y0 = r*sin(theta); s = min( (x0-X).^2 + (y0-Y).^2 ); % 最小圆心距离 if s < 10^2 continue; else X = [X;x0]; % 圆心坐标集合 Y = [Y;y0]; n = n +1 % 点数 end end toc alpha = linspace(0,2*pi,100); x = 5*cos(alpha); y = 5*sin(alpha); figure plot( 150*x,150*y,'r' ) hold on for ii = 1:n x0 = X(ii); y0 = Y(ii); plot(x0+x,y0+y,'k') end
结果:
n =1000
历时 0.183838 秒。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决评论 打赏 举报无用 1
悬赏问题
- ¥15 深度学习中模型转换该怎么实现
- ¥15 HLs设计手写数字识别程序编译通不过
- ¥15 Stata外部命令安装问题求帮助!
- ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
- ¥15 TYPCE母转母,插入认方向
- ¥15 如何用python向钉钉机器人发送可以放大的图片?
- ¥15 matlab(相关搜索:紧聚焦)
- ¥15 基于51单片机的厨房煤气泄露检测报警系统设计
- ¥15 Arduino无法同时连接多个hx711模块,如何解决?
- ¥50 需求一个up主付费课程