N层循环

  1. #include <stdio.h>
  2. /*打印数组*/
  3. extern void print_array(int array[], int size);
  4. int visited[3] = {0};
  5. int main_n_loop(){
  6.     int k = 2;
  7.     visited[k] = -1;
  8.     while(1){
  9.         if(visited[k] < 1){
  10.             visited[k]++;
  11.             k = 2;
  12.             /*do something*/
  13.             print_array(visited, 3);
  14.         }else{
  15.             visited[k] = 0;
  16.             k--;
  17.         }
  18.         if(k < 0)
  19.             break;
  20.     }
  21.     return 0;
  22. }
 两段代码都完成模拟n层循环的功能,第二段比较具体

  1. #include <stdio.h>
  2. int array[5] = {0};
  3. int limit[5] = {10,10,10,10,10};/*每层循环都有一个上限,到达上限将置0*/
  4. /*print every item of array*/
  5. void print_array(int array[], int size){
  6.     for(int i = 0; i < size; i++){
  7.         printf("%d ", array[i]);
  8.     }
  9.     printf("/n");
  10. }
  11. /*实现任意n层循环*/
  12. void m_step_loop1(int array[], int limit[], int size){
  13.     int k = size - 1;
  14.     
  15.     while(true){
  16.         while(k >= 0){
  17.             if(array[k] < limit[k] - 1){
  18.                 array[k]++;
  19.                 k = size - 1; /*再无进位则退至最后一位循环*/
  20.                 break;
  21.             }else{
  22.                 array[k] = 0;
  23.                 k -- ;
  24.             }
  25.         }
  26.         if(k < 0)
  27.             break;
  28.         /*add your code here*/
  29.         print_array(array, size);
  30.     }
  31. }
  32. int m_step_loop_main(){
  33.     m_step_loop1(array, limit, 2);
  34.     return 0;
  35. }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值