24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1653  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 复试调剂 +12 呼呼?~+123456 2026-04-05 12/600 2026-04-05 14:15 by shanshui11
[考研] 一志愿上海海洋大学083200食品学硕,求调剂,接受其他专业083200 +4 what张 2026-04-04 5/250 2026-04-05 14:07 by chw1980_0
[考研] 生物与医药调剂 +3 十七sa 2026-04-05 3/150 2026-04-05 13:28 by jp9609
[考研] 312求调剂 +3 Say Never 2026-04-04 3/150 2026-04-05 11:19 by guoweigw
[考研] 298求调剂 +7 manman511 2026-04-05 7/350 2026-04-05 10:29 by 唐沐儿
[考研] 求生物学调剂 +14 15172915737 2026-04-01 14/700 2026-04-04 20:13 by babysonlkd
[考研] 11408 一志愿西电,277分求调剂 +4 zhouzhen654 2026-04-03 4/200 2026-04-04 18:10 by 猪会飞
[考研] 26调剂 086003 +6 失活的细胞 2026-04-04 6/300 2026-04-04 09:50 by zhangdingwa
[考研] 266求调剂 +8 学员97LZgn 2026-04-03 8/400 2026-04-04 09:02 by 20021109
[考研] 387求调剂 +4 爱吃片豆土 2026-04-03 5/250 2026-04-04 08:10 by 岸上的一条鱼
[考研] 303求调剂 +10 DLkz1314. 2026-03-30 10/500 2026-04-03 18:03 by Jimmyandyou
[考研] 求调剂 +4 15064154688 2026-04-03 5/250 2026-04-03 15:07 by zrongyan
[考研] 261求B区调剂 +5 明仔· 2026-04-01 7/350 2026-04-02 11:17 by 邹尉尉
[考研] 08生物与医药专硕初试346找调剂 +6 dianeeee 2026-04-01 7/350 2026-04-02 08:23 by guoweigw
[考研] 085410 一志愿211 22408分数359求调剂 +3 123456789qw 2026-03-31 4/200 2026-04-02 00:06 by 义文wang
[考研] 279求调剂 +7 莫xiao 2026-04-01 7/350 2026-04-01 22:05 by 客尔美德
[考研] 求调剂 +4 DADA怪 2026-03-31 4/200 2026-04-01 14:30 by ZXlzxl0425
[考研] 267求调剂 +13 uiybh 2026-03-31 13/650 2026-04-01 10:25 by 探123
[考研] 考研调剂求助 +7 13287130938 2026-03-31 7/350 2026-03-31 16:39 by 690616278
[考研] 一志愿大连理工大学材料求调剂 +6 Gymno 2026-03-30 6/300 2026-03-31 07:26 by 无际的草原
信息提示
请填处理意见