24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1721  |  回复: 11

ahuang1985

铁虫 (小有名气)

[求助] 拜托大家帮忙看个简单程序

本意是想从-10—10范围内随机产生10个不同的坐标点,并且满足该坐标到原点的距离小于等于10.  关于控制距离,我这样操作的:            
if(pow((b), 2) + pow((d), 2) + pow((f), 2) > 100.0)
                {
                 i=i-1;
                }

运行的结果是不同的点倒是产生了,但是距离小于10不满足。哪个大侠帮帮忙看看怎么改,多谢了! 程序如下:



#include
#include
#include
#define N 10

int main(void)
{

        int a[20]={0},b[N],x,y,z,i,j,t;
        int c[20]={0},d[N],e[20]={0},f[N];
        srand((unsigned int)time(NULL));
        for (i=0;i         {
                while(a[x=rand()%21-10]);
                {
                        b=x;
                        a[x]=1;

                }
                while(c[y=rand()%21-10]);
                {
                        d=y;
                        c[y]=1;

                }
                while(e[z=rand() %21-10]);
                {
                        f=z;
                        e[z]=1;

                }
              if(pow((b), 2) + pow((d), 2) + pow((f), 2) > 100.0)
                {
                 i=i-1;
                }

        }

        for(i =0 ;i         {
                printf("%4d,%4d,%4d\n ",b,d,f);
        }

}
回复此楼

» 本帖已获得的红花(最新10朵)

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

好像字体倾斜了,不太清楚 再传一次

#include
#include
#include
#define N 10

int main(void)
{

        int a[20]={0},b[N],x,y,z,i,j,t;
        int c[20]={0},d[N],e[20]={0},f[N];
        srand((unsigned int)time(NULL));
        for (i=0;i         {
                while(a[x=rand()%21]);
                {
                        b=x-10;
                        a[x]=1;

                }
                while(c[y=rand()%21]);
                {
                        d=y-10;
                        c[y]=1;

                }
                while(e[z=rand() %21]);
                {
                        f=z-10;
                        e[z]=1;

                }
              if(pow((b), 2) + pow((d), 2) + pow((f), 2) > 100.0)
                {
                 i=i-1;
                }

        }

        for(i =0 ;i         {
                printf("%4d,%4d,%4d\n ",b,d,f);
        }

}
2楼2012-03-21 11:11:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

自己顶吧,忘了
#include
3楼2012-03-21 12:21:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

锐利的碎片

木虫 (正式写手)

star watcher

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
ahuang1985: 金币+6, ★★★很有帮助, 多谢! 2012-03-21 12:43:01
xzhdty: 金币+1, 欢迎常来程序语言 2012-03-21 19:02:05
CODE:
#include
#include
#include

#define N 10

int main(int argc, char **argv)
{
    int i, x, y, z, pt[N][3];
    double dist;

    srand(time(NULL));
    for ( i = 0; i < N; i++ ) {
        do {
            x = rand()%21 - 10;
            y = rand()%21 - 10;
            z = rand()%21 - 10;
            dist = sqrt(pow((double) x, 2) +
                        pow((double) y, 2) +
                        pow((double) z, 2));
        } while (dist > 10.0);
        pt[i][0] = x;
        pt[i][1] = y;
        pt[i][2] = z;
        printf("%4d %4d %4d %f\n", pt[i][0], pt[i][1], pt[i][2], dist);
    }

    return 0;
}

» 本帖已获得的红花(最新10朵)

4楼2012-03-21 12:22:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

送鲜花一朵
引用回帖:
4楼: Originally posted by 锐利的碎片 at 2012-03-21 12:22:48:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#define N 10

int main(int argc, char **argv)
{
    int i, x, y, z, pt;
    double dist;

    srand(time(NUL ...

多谢帮忙,小弟还有一个问题,就是从-9.5—9.5范围内也随机产生10个不同的坐标点,(都是整数带0.5),距离满足小于等于10;
但是怎样使前面产生的10个坐标点和后面这10个坐标点合并成一个数组?不用排序。我弄了半天都运行不成功,帮帮忙哈~ 多谢了!
5楼2012-03-21 13:44:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

锐利的碎片

木虫 (正式写手)

star watcher


xzhdty: 金币+1, 谢谢参与 2012-03-21 19:02:38
CODE:
#include
#include
#include

#define N 10

int main(int argc, char **argv)
{
    int i, x, y, z;
    double dist, pt[2*N][3];

    srand(time(NULL));
    for ( i = 0; i < N; i++ ) {
        do {
            x = rand()%21 - 10;
            y = rand()%21 - 10;
            z = rand()%21 - 10;
            dist = sqrt(pow((double) x, 2) +
                        pow((double) y, 2) +
                        pow((double) z, 2));
        } while (dist > 10.0);
        pt[i][0] = (double) x;
        pt[i][1] = (double) y;
        pt[i][2] = (double) z;
        printf("%f %f %f %f\n", pt[i][0], pt[i][1], pt[i][2], dist);
    }
   
    for ( i = N; i < 2*N; i++) {
        do {
            x = rand()%39 - 19;
            y = rand()%39 - 19;
            z = rand()%39 - 19;
            dist = sqrt(pow(0.5 * x, 2) +
                        pow(0.5 * y, 2) +
                        pow(0.5 * z, 2));
        } while (dist > 10.0);
        pt[i][0] = 0.5*x;
        pt[i][1] = 0.5*y;
        pt[i][2] = 0.5*z;
        printf("%f %f %f %f\n", pt[i][0], pt[i][1], pt[i][2], dist);
    }

    return 0;
}

» 本帖已获得的红花(最新10朵)

6楼2012-03-21 14:58:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

送鲜花一朵
多谢大帅哥!
7楼2012-03-21 16:00:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

送鲜花一朵
引用回帖:
6楼: Originally posted by 锐利的碎片 at 2012-03-21 14:58:30:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#define N 10

int main(int argc, char **argv)
{
    int i, x, y, z;
    double dist, pt;

    srand(time(NUL ...

多谢大帅哥!
8楼2012-03-21 16:00:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

引用回帖:
6楼: Originally posted by 锐利的碎片 at 2012-03-21 14:58:30:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#define N 10

int main(int argc, char **argv)
{
    int i, x, y, z;
    double dist, pt;

    srand(time(NUL ...

小弟再请教一个问题哈,太麻烦你了。就是前面不是得到了一些随机产生的坐标点吗,这里还存在一个动态坐标点(R1,R2,R3),下面for循环外面还有一个循环(即下面所标外循环),就是我想获得的(R1,R2,R3)坐标值只要和前面随机产生的坐标点一致,外循环就终止。
问题是我想比较所有的这些随机产生的坐标点,需要通过数组形式,如下for循环,但是break只能跳出一个循环,跳不出外面的大循环,所以不起作用。 应该怎样弄呢?我不知道我讲明白了没,有劳兄弟帮我看看,多谢啦!

外循环:{
    for ( i= N1; i
           if(pow((R1-pt[0]), 2) + pow((R2-pt[1]), 2) + pow((R3-pt[2]), 2)=0)
           {
                break;
           }
         }
}
9楼2012-03-21 22:24:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

外循环:{
    for ( i= N1; i
           if(pow((R1-pt[0]), 2) + pow((R2-pt[1]), 2) + pow((R3-pt[2]), 2)=0)
           {
                break;
           }
         }
}
10楼2012-03-21 22:28:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ahuang1985 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考博] 华师大读博 +3 xq83 2026-04-22 3/150 2026-04-22 03:56 by 啊哒哒哒叨
[论文投稿] 急需审稿人!!! +3 陆小果画大饼 2026-04-21 3/150 2026-04-21 23:54 by jzy_123456
[考博] 申博/考博 +4 啃面包的小书虫 2026-04-17 8/400 2026-04-21 16:26 by 啃面包的小书虫
[考研] 一志愿A区211,22408 321求调剂 +7 随心所欲☆ 2026-04-15 8/400 2026-04-21 08:22 by Equinoxhua
[考研] 295分求调剂 +6 ?要上岸? 2026-04-17 6/300 2026-04-21 08:18 by Equinoxhua
[考研] 085600材料与化工调剂 5+3 孜孜不倦2002 2026-04-19 6/300 2026-04-20 21:25 by babero
[论文投稿] 有没有接收比较快的sci期刊呀,最好在一个月之内的,研三孩子求毕业 20+4 之护着 2026-04-16 7/350 2026-04-20 15:45 by 豆豆7758
[教师之家] 又一批高校组建人工智能学院 师资行吗 不是骗人吗 +4 yexuqing 2026-04-19 4/200 2026-04-20 14:47 by brantleo
[考研] 337求调剂 +3 jyz04 2026-04-18 3/150 2026-04-20 12:24 by 研可安
[考博] 申博 +3 Xyyx. 2026-04-18 3/150 2026-04-20 10:44 by YuY66
[考研] 304求调剂 +8 castLight 2026-04-16 8/400 2026-04-19 17:14 by 中豫男
[考研] 求调剂 +10 小聂爱学习 2026-04-16 12/600 2026-04-19 16:51 by 中豫男
[考研] 求调剂 +6 苦命人。。。 2026-04-18 7/350 2026-04-19 16:27 by 中豫男
[考研] 294求调剂 +15 淡然654321 2026-04-15 15/750 2026-04-19 08:20 by cuisz
[考研] 0854求调剂 +23 门路摸摸 2026-04-15 27/1350 2026-04-19 01:59 by 烟雨流涯
[考研] 接受任何调剂 +6 也就是栗子 2026-04-17 7/350 2026-04-18 17:20 by 涵竹刘
[考研] 收到复试调剂但是去不了 +8 小蜗牛* 2026-04-16 8/400 2026-04-18 11:15 by zixin2025
[考研] 急需调剂 +9 绝不放弃22 2026-04-15 10/500 2026-04-18 08:09 by chixmc
[有机交流] 二苯甲酮酸类衍生物 50+3 小白爱主人 2026-04-17 6/300 2026-04-17 18:47 by kf2781974
[考研] 一志愿沪9,生物学326求调剂 +9 刘墨墨 2026-04-15 9/450 2026-04-16 17:14 by 崔崔崔cccc
信息提示
请填处理意见