24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1779  |  回复: 7

ahuang1985

铁虫 (小有名气)

[求助] MC一个简单的程序,运行不了,哪位大侠帮看看怎么回事。多谢!

如题,哪位大侠帮看看怎么回事。万分感谢!
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : 0222.c
  • 2012-02-22 10:39:30, 1.09 K

» 猜你喜欢

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

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

锐利的碎片

木虫 (正式写手)

star watcher

【答案】应助回帖

感谢参与,应助指数 +1
余泽成(金币+2): 谢谢参与应助! 2012-02-25 04:26:16
#include
#include
#include
#include

int main(void)
{  
    double avg=0;
    float Run=0.0;
    int n=1,t=0;
    int FN;
    int R1,R2,R3;
    for (n=1;n<=100;n++){  
        FN=0;
        while (FN<100)
        {
            srand((unsigned)time(NULL));
            Run=rand()/(RAND_MAX+1.0);
            if(0 <= Run < 0.125){
                R1=R1+1;
                R2=R2+1;
                R3=R3+1;
            }
            if(0.125 <= Run < 0.250){
                R1=R1-1;
                R2=R2+1;
                R3=R3+1;
            }
            if(0.250 <= Run < 0.375){
                R1=R1-1;
                R2=R2-1;
                R3=R3+1;
            }
            if(0.375<=Run<0.500){
                R1=R1+1;
                R2=R2-1;
                R3=R3+1;
            }
            if(0.500<=Run<0.625){
                R1=R1+1;
                R2=R2+1;
                R3=R3-1;
            }
            if(0.625<=Run<0.750){
                R1=R1-1;
                R2=R2+1;
                R3=R3-1;
            }
            if(0.750<=Run<0.875){
                R1=R1-1;
                R2=R2-1;
                R3=R3-1;
            }
            else{
                R1=R1+1;
                R2=R2-1;
                R3=R3-1;
            }
            t=t+1;
            FN=pow((R1-100), 2)+pow((R2-100), 2)+pow((R3-100), 2);
            if(FN==100)
            {
                break;
            }

        }
  
    }
    avg=t/100.0;
    printf("Result avg=t/100.0= %lf\n",avg);
    return 0;
}
改了下, 你看看。
2楼2012-02-22 10:59:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

引用回帖:
: Originally posted by 锐利的碎片 at 2012-02-22 10:59:18:
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(void)
{  
    double avg=0;
    float Run=0.0;
    int n=1,t=0;
    int FN;
...

#include
#include
#include
#include

int main(void)
{  
    double avg=0;
    float Run=0.0;
    int n,t=0;
    int FN;
    int R1=100,R2=100,R3=100;
    srand((unsigned)time(NULL));
    for (n=1;n<=100;n++){
       FN=0;
        while (1)
        {
     printf("n=%d,t=%d\n",n,t);
        if(FN<100){
            Run=rand()/(RAND_MAX+1.0);
        printf("Run=%lf,FN=%d\n",Run,FN);
            if(Run < 0.125){
                R1=R1+1;
                R2=R2+1;
                R3=R3+1;
            }
            if(0.125 <= Run < 0.250){
                R1=R1-1;
                R2=R2+1;
                R3=R3+1;
            }
            if(0.250 <= Run < 0.375){
                R1=R1-1;
                R2=R2-1;
                R3=R3+1;
            }
            if(0.375<=Run<0.500){
                R1=R1+1;
                R2=R2-1;
                R3=R3+1;
            }
            if(0.500<=Run<0.625){
                R1=R1+1;
                R2=R2+1;
                R3=R3-1;
            }
            if(0.625<=Run<0.750){
                R1=R1-1;
                R2=R2+1;
                R3=R3-1;
            }
            if(0.750<=Run<0.875){
                R1=R1-1;
                R2=R2-1;
                R3=R3-1;
            }
           else if (Run>=0.875){
                R1=R1+1;
                R2=R2-1;
                R3=R3-1;
            }
  FN = pow((R1-100), 2) + pow((R2-100), 2) + pow((R3-100), 2);
            t=t+1;
            }
            if(FN>=100)
            {
                break;
            }

        }
  
    }
    avg=t/100.0;
    printf("Result avg=t/100.0= %lf\n",avg);
    return 0;
}

谢谢! 我上次传的没有设置R1,R2,R3的初始条件,修改了下,能运行了,可是结果明显不对啊。。。 我是想进行100次试验的。 可是后来FN的值一直为0啊。 搞不懂啦。。晕啊,能再帮我看看不,多谢了!
3楼2012-02-22 14:10:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

引用回帖:
: Originally posted by 锐利的碎片 at 2012-02-22 10:59:18:
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(void)
{  
    double avg=0;
    float Run=0.0;
    int n=1,t=0;
    int FN;
...

我的目的是想弄一个模型,就是在体心立方晶体中原子的随机扩散,有八个方向不是,计算最终达到离原来距离为10的时候所需要的跃迁次数。
4楼2012-02-22 14:13:28
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hwf04

金虫 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
jjdg(金币+1): 【版主管理指数】 = 0.848 2012-02-24 23:41:07
简单看了一下  FN只在循环里赋了一次值0,应该再循环外给初值,再循环里每循环一次加1  ,这样FN才随循环改变   
不知是不是这样的

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

等待只因值得,隐忍只为爆发。
5楼2012-02-22 16:41:22
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

送鲜花一朵
引用回帖:
: Originally posted by hwf04 at 2012-02-22 16:41:22:
简单看了一下  FN只在循环里赋了一次值0,应该再循环外给初值,再循环里每循环一次加1  ,这样FN才随循环改变   
不知是不是这样的

多谢帮忙哈,我的这里FN是不能每循环一次加1的,因为这个FN是与其他因素相关联的,有用的。 我鼓捣了一晚上还是没弄好,一开始n=1的时候,FN还能获得其他值,后来n=2-100的时候,FN总是0,郁闷啊, 我C不太懂, 麻烦你再帮我看看啊,多谢!
6楼2012-02-22 20:52:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hwf04

金虫 (正式写手)


jjdg(金币+2): 感谢参与 2012-02-24 23:35:52
引用回帖:
6楼: Originally posted by ahuang1985 at 2012-02-22 20:52:06:
多谢帮忙哈,我的这里FN是不能每循环一次加1的,因为这个FN是与其他因素相关联的,有用的。 我鼓捣了一晚上还是没弄好,一开始n=1的时候,FN还能获得其他值,后来n=2-100的时候,FN总是0,郁闷啊, 我C不太懂,  ...

你这个n从1-100是不是都是一个新的计算?如果是独立的重新计算那R1,R2,R3是每次n增加后都要重新赋值吧,你这里只给了一次赋值,之后的都是用上一次的计算后的结果  所以FN只计算一次

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

等待只因值得,隐忍只为爆发。
7楼2012-02-24 11:44:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ahuang1985

铁虫 (小有名气)

送鲜花一朵
余泽成: 在他回复的帖子里面有赠与金币,点击,填写金币数额! 2012-02-25 04:27:46
引用回帖:
: Originally posted by hwf04 at 2012-02-24 11:44:21:
你这个n从1-100是不是都是一个新的计算?如果是独立的重新计算那R1,R2,R3是每次n增加后都要重新赋值吧,你这里只给了一次赋值,之后的都是用上一次的计算后的结果  所以FN只计算一次

嗯,是这样的,改了运行成功了,多谢啊!!我是新手,怎样给你金币呢?
8楼2012-02-24 21:58:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ahuang1985 的主题更新
信息提示
请填处理意见