加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

对于循环增强但含糊不清

发布时间:2020-12-16 09:48:08 所属栏目:百科 来源:网络整理
导读:我想知道的是这个陈述是否可行 for(j = 2; (j = i) flag; j++) flag在此循环之前初始化为i.我以前没见过这样的事. 解决方法 循环条件的一般情况如下: – for(initialization ; condition; increment) 所以你所做的是正确的. 打破你的for循环意味着: – for
我想知道的是这个陈述是否可行

for(j = 2; (j <= i) && flag; j++)

flag在此循环之前初始化为i.我以前没见过这样的事.

解决方法

循环条件的一般情况如下: –

for(initialization ; condition; increment)

所以你所做的是正确的.

打破你的for循环意味着: –

for(j=2;(j<=i)&& flag ;j++)

初始化是j = 2;

条件是(j <= i)&&旗帜 增量是j 一个例子: –

int main(int argc,const char * argv[])
{
    int sum = 0;
    int j = 100;
    for(int i = 1; i<=100/2 && j>100/2; i++){
        sum += i+j;
        j--;
    }

    return sum;

}

带标志的第二个例子:

记住bubble sort,在冒泡排序中我们需要两个嵌套循环,外循环运行多次传递,内循环执行每个对a [i],a [i 1]的交换任务.为了节省执行,我们可以使用一些标志变量.如果在某些传递中没有进行交换,这意味着不需要执行下一遍并完成排序,请阅读:Optimizing bubble sort:

现在代码为:

FLAG = 1;
for(i = 0; FLAG && (i < n - 1); i++){//If flag = ),break outer loop sorting done
  FLAG = 0; // set flag = 0
  for(j = 0; j < n - 1 - i; j++){
   if(arr[j] > arr[j + 1]){
    swap(arr[j],arr[j + 1]);
    FLAG = 1; // if any swapping need,then check in next round  
   }
 }
}

注意外环状况FLAG&& (i< n - 1),我想这就是你想要的.希望这有帮助!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读