while循环条件不满足

while loop condition not fullfiled

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 条件应该是这样。请帮忙。

我想你需要 do-while-loop 这里。它将至少执行一次代码块,然后重复执行该块,或者停止执行它,具体取决于块末尾的布尔条件。

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

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

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

您的代码片段等同于以下内容

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);