24小时热门版块排行榜    

查看: 1588  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 290求调剂 +5 孔志浩 2026-03-12 10/500 2026-03-16 09:01 by 余晖&
[考研] 326求调剂 +4 上岸的小葡 2026-03-15 5/250 2026-03-16 08:39 by Linda Hu
[考研] 材料与化工一志愿南昌大学327求调剂推荐 +6 Ncdx123456 2026-03-13 7/350 2026-03-16 07:44 by L135790
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 调剂 +8 调剂的考研学生 2026-03-09 8/400 2026-03-15 22:14 by Winj1e
[考研] 机械专硕调剂 +3 笨笨兔子 2026-03-12 3/150 2026-03-15 20:02 by 栗子粥?
[考研] 26考研一志愿中国石油大学(华东)305分求调剂 +3 嘉年新程 2026-03-15 3/150 2026-03-15 13:58 by 哈哈哈哈嘿嘿嘿
[考研] 311求调剂 +3 26研0 2026-03-15 3/150 2026-03-15 09:12 by JourneyLucky
[考研] 085600材料与化工 326 求调剂 +5 热爱生活ing 2026-03-09 5/250 2026-03-14 02:39 by JourneyLucky
[考研] 一志愿华中农业大学071010,总分三百二,求调剂 +3 困困困困坤坤 2026-03-10 3/150 2026-03-14 00:35 by JourneyLucky
[考研] 327求调剂 +4 Ffff03 2026-03-10 4/200 2026-03-14 00:17 by JourneyLucky
[考研] 341求调剂 +3 番茄头--- 2026-03-10 3/150 2026-03-13 23:07 by JourneyLucky
[考研] 285 求调剂 资源与环境 一志愿北京化工大学 +3 未名考生 2026-03-10 3/150 2026-03-13 23:04 by JourneyLucky
[考研] 279求调剂 +3 Dizzy123@ 2026-03-10 3/150 2026-03-13 23:02 by JourneyLucky
[考研] 308求调剂 +5 是Lupa啊 2026-03-11 5/250 2026-03-13 22:13 by JourneyLucky
[考研] 285化工学硕求调剂(081700) +6 柴郡猫_ 2026-03-12 6/300 2026-03-13 20:46 by hmn_wj
[考研] 一志愿211化学学硕310分求调剂 +8 努力奋斗112 2026-03-12 9/450 2026-03-13 15:41 by JourneyLucky
[考研] 295求调剂 +3 小匕仔汁 2026-03-12 3/150 2026-03-13 15:17 by vgtyfty
[考研] 070303一志愿西北大学学硕310找调剂 +3 d如愿上岸 2026-03-13 3/150 2026-03-13 10:43 by houyaoxu
[考研] 0856化工原理 +6 z2839474511 2026-03-10 6/300 2026-03-13 10:41 by houyaoxu
信息提示
请填处理意见