24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1778  |  回复: 7
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

ahuang1985

铁虫 (小有名气)

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

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

» 本帖附件资源列表

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

» 猜你喜欢

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

已阅   回复此楼   关注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的回帖
查看全部 8 个回答

锐利的碎片

木虫 (正式写手)

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的回帖
信息提示
请填处理意见