while 循环条件未满足

时间:2021-04-05 16:53:07

标签: c loops while-loop do-while

double randomx,randomy,randomz,dia;
#define DROP_RAD 60
#define particleradi 3

for (i = 0; i<30; i++) 
{
    {
        randomx=2*((float)rand()/RAND_MAX)-1;
        randomy=2*((float)rand()/RAND_MAX)-1;
        randomz=2*((float)rand()/RAND_MAX)-1;
        randomx=randomx*(DROP_RAD -2*particleradi);
        randomy=randomy*(DROP_RAD -2*particleradi);
        randomz=randomz*(DROP_RAD -2*particleradi);
        
        dia=randomx*randomx+randomy*randomy+randomz*randomz;
        dia=sqrt(dia);
    
    } while(dia>DROP_RAD);

    
    printf(" id=%d, x=%lf, y=%lf, z=%lf , dia=%lf\n ",i,randomx,randomy,randomz,dia);

我得到的 dia 值大于 DROP_RAD,即使 while 条件应该是这样。请帮忙。

2 个答案:

答案 0 :(得分:1)

我认为您需要一个 do-while-loop。它将至少执行一次代码块,然后根据块末尾的布尔条件,重复执行该块,或者停止执行它。

do {
    /* here goes your code */
} while (dia > DROP_RAD);

如果您根本不想在条件为 false 时执行块,则必须将条件移动到块的开头。

while (dia > DROP_RAD) {
    /* here goes your code */
}

答案 1 :(得分:1)

您的代码片段相当于以下内容

for (i = 0; i<30; i++) 
{

    {
        randomx=2*((float)rand()/RAND_MAX)-1;
        randomy=2*((float)rand()/RAND_MAX)-1;
        randomz=2*((float)rand()/RAND_MAX)-1;
        randomx=randomx*(DROP_RAD -2*particleradi);
        randomy=randomy*(DROP_RAD -2*particleradi);
        randomz=randomz*(DROP_RAD -2*particleradi);
  
        dia=randomx*randomx+randomy*randomy+randomz*randomz;
        dia=sqrt(dia);
    }

    while(dia>DROP_RAD);


    printf(" id=%d, x=%lf, y=%lf, z=%lf , dia=%lf\n ",i,randomx,randomy,randomz,dia);

    //...

那是你有一个复合语句

    {
        randomx=2*((float)rand()/RAND_MAX)-1;
        // ...
    }

后跟一个单独的while语句

while(dia>DROP_RAD);

所以要么你有一个无限的 while 循环

while(dia>DROP_RAD);

如果 dia 大于 DROP_RAD 或者如果条件不满足则立即中断循环。

看来你的意思是像一个 do-while 循环

do {
    randomx=2*((float)rand()/RAND_MAX)-1;
    randomy=2*((float)rand()/RAND_MAX)-1;
    randomz=2*((float)rand()/RAND_MAX)-1;
    randomx=randomx*(DROP_RAD -2*particleradi);
    randomy=randomy*(DROP_RAD -2*particleradi);
    randomz=randomz*(DROP_RAD -2*particleradi);

    dia=randomx*randomx+randomy*randomy+randomz*randomz;
    dia=sqrt(dia);
} while(dia>DROP_RAD);