鱼C论坛

 找回密码
 立即注册
查看: 2897|回复: 7

[已解决]猴子排序一直出不来循环

[复制链接]
发表于 2021-5-19 23:19:01 | 显示全部楼层 |阅读模式
10鱼币
请问大佬们,这代码是哪里有问题?
看似没问题每次随机都不一样,但是几分钟上百万次都随机不出正确答案。。。
顺带请教一下这种随机性代码怎么检查它有没有错过正确答案?
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<time.h>

  4. void bogo_sort(int*,int);

  5. int main(void)
  6. {
  7.         int array[] = {73, 108, 111, 118, 101, 70, 105, 104, 67};
  8.         int i, length;
  9.         time_t begin, end;

  10.       
  11.         begin = time(NULL);

  12.         length = sizeof(array) / sizeof(array[0]);//length = 9;
  13.         bogo_sort(array, length);

  14.         printf("排序后的结果是:");
  15.         for (i = 0; i < length; i++)
  16.         {
  17.                 printf("%d ", array[i]);
  18.         }
  19.         putchar('\n');

  20.         end = time(NULL);
  21.         printf("总共耗时:%ld秒\n", end - begin);

  22.         return 0;
  23. }

  24. void bogo_sort(int *array,int length)
  25. {
  26.         int num1[length];//存放num2的下标
  27.         int num2[length];//储存array的随机排序
  28.         char ch;//判断数组是否排序成功
  29.         int i,j;
  30.         int count = 1;

  31.         srand((unsigned)time(NULL));
  32.         do{

  33.                 for(i = 0;i < length;i++)
  34.                 {
  35.                         num1[i] = rand()%length;
  36.                         for(j = 0;j < i;j++)
  37.                         {
  38.                                 if(num1[j] == num1[i])
  39.                                 {
  40.                                         i--;
  41.                                         break;
  42.                                 }//保证下标不重复
  43.                  }
  44.                 }//随机生成num2的下标

  45.                 printf("第%d次num2的下标为:",count ++);
  46.                 for(i = 0;i < length;i ++)
  47.                 {
  48.                         printf("%d ",num1[i]);
  49.                 }
  50.                 putchar('\n');

  51.                 for(i = 0;i < length;i ++)
  52.                 {
  53.                         num2[num1[i]] = array[i];
  54.                 }//用num2存放随机排序的array数组
  55.                 for(i = 0;i < length;i ++)
  56.                 {
  57.                         for(j = 0;j < i;j ++)
  58.                         {
  59.                                 if(num2[j] > num2[i])
  60.                                 {
  61.                                         ch = 'N';
  62.                                         break;
  63.                                 }
  64.                                 ch = 'Y';
  65.                         }//检查num是否从小到大排序,成功为Y,不成功为N
  66.                         if(ch == 'N')
  67.                         {
  68.                                 break;
  69.                         }//没有正确排序直接进入下一次循环
  70.                 }
  71.                 printf("排序后的结果是:");
  72.                 for(i = 0;i < length;i ++)
  73.                 {
  74.                         printf("%d ",num2[i]);
  75.                 }
  76.                 putchar('\n');
  77.         }while(ch == 'N');

  78.         for(i =0;i <length;i ++)
  79.         {
  80.                 printf("我到了结尾!\n");
  81.                 array[i] = num2[i];
  82.         }//将排序好的数组放入array
  83. }
复制代码
最佳答案
2021-5-19 23:19:02
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<time.h>

  4. void bogo_sort(int*,int);

  5. int main(void)
  6. {
  7.     int array[] = {73, 108, 111, 118, 101, 70, 105, 104, 67};
  8.     //int array[] = {73, 108, 111};
  9.     int i, length;
  10.     time_t begin, end;


  11.     begin = time(NULL);

  12.     length = sizeof(array) / sizeof(array[0]);//length = 9;
  13.     bogo_sort(array, length);

  14.     printf("排序后的结果是:");
  15.     for (i = 0; i < length; i++)
  16.     {
  17.         printf("%d ", array[i]);
  18.     }
  19.     putchar('\n');

  20.     end = time(NULL);
  21.     printf("总共耗时:%ld秒\n", end - begin);

  22.     return 0;
  23. }

  24. void bogo_sort(int *array,int length)
  25. {
  26.     int num1[length];//存放num2的下标
  27.     int num2[length];//储存array的随机排序
  28.     char ch;//判断数组是否排序成功
  29.     int i,j;
  30.     int count = 1;

  31.     srand((unsigned)time(NULL));
  32.     do{

  33.         for(i = 0;i < length;i++)
  34.         {
  35.             num1[i] = rand()%length;
  36.             for(j = 0;j < i;j++)
  37.             {
  38.                 if(num1[j] == num1[i])
  39.                 {
  40.                     i--;
  41.                     break;
  42.                 }//保证下标不重复
  43.             }
  44.         }//随机生成num2的下标

  45.         printf("第%d次num2的下标为:",count ++);
  46.         for(i = 0;i < length;i ++)
  47.         {
  48.             printf("%d ",num1[i]);
  49.         }
  50.         putchar('\n');

  51.         for(i = 0;i < length;i ++)
  52.         {
  53.             num2[num1[i]] = array[i];
  54.         }//用num2存放随机排序的array数组
  55.         /*
  56.         for(i = 0;i < length;i ++)
  57.         {
  58.             for(j = 0;j < i;j ++)
  59.             {
  60.                 if(num2[j] > num2[i])
  61.                 {
  62.                     ch = 'N';
  63.                     break;
  64.                 }
  65.                 ch = 'Y';
  66.             }//检查num是否从小到大排序,成功为Y,不成功为N
  67.             if(ch == 'N')
  68.             {
  69.                 break;
  70.             }//没有正确排序直接进入下一次循环
  71.         }
  72.         */
  73.         ch = 'Y';
  74.         for(int i = 0; i < length - 1; ++i) {
  75.             if(num2[i] > num2[i + 1]) {
  76.                 ch = 'N';
  77.                 break;
  78.             }
  79.         }
  80.         printf("排序后的结果是:");
  81.         for(i = 0;i < length;i ++)
  82.         {
  83.             printf("%d ",num2[i]);
  84.         }
  85.         putchar('\n');
  86.     }while(ch == 'N');

  87.     for(i =0;i <length;i ++)
  88.     {
  89.         printf("我到了结尾!\n");
  90.         array[i] = num2[i];
  91.     }//将排序好的数组放入array
  92. }
复制代码
问题1.png
问题2.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-5-19 23:19:02 | 显示全部楼层    本楼为最佳答案   
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<time.h>

  4. void bogo_sort(int*,int);

  5. int main(void)
  6. {
  7.     int array[] = {73, 108, 111, 118, 101, 70, 105, 104, 67};
  8.     //int array[] = {73, 108, 111};
  9.     int i, length;
  10.     time_t begin, end;


  11.     begin = time(NULL);

  12.     length = sizeof(array) / sizeof(array[0]);//length = 9;
  13.     bogo_sort(array, length);

  14.     printf("排序后的结果是:");
  15.     for (i = 0; i < length; i++)
  16.     {
  17.         printf("%d ", array[i]);
  18.     }
  19.     putchar('\n');

  20.     end = time(NULL);
  21.     printf("总共耗时:%ld秒\n", end - begin);

  22.     return 0;
  23. }

  24. void bogo_sort(int *array,int length)
  25. {
  26.     int num1[length];//存放num2的下标
  27.     int num2[length];//储存array的随机排序
  28.     char ch;//判断数组是否排序成功
  29.     int i,j;
  30.     int count = 1;

  31.     srand((unsigned)time(NULL));
  32.     do{

  33.         for(i = 0;i < length;i++)
  34.         {
  35.             num1[i] = rand()%length;
  36.             for(j = 0;j < i;j++)
  37.             {
  38.                 if(num1[j] == num1[i])
  39.                 {
  40.                     i--;
  41.                     break;
  42.                 }//保证下标不重复
  43.             }
  44.         }//随机生成num2的下标

  45.         printf("第%d次num2的下标为:",count ++);
  46.         for(i = 0;i < length;i ++)
  47.         {
  48.             printf("%d ",num1[i]);
  49.         }
  50.         putchar('\n');

  51.         for(i = 0;i < length;i ++)
  52.         {
  53.             num2[num1[i]] = array[i];
  54.         }//用num2存放随机排序的array数组
  55.         /*
  56.         for(i = 0;i < length;i ++)
  57.         {
  58.             for(j = 0;j < i;j ++)
  59.             {
  60.                 if(num2[j] > num2[i])
  61.                 {
  62.                     ch = 'N';
  63.                     break;
  64.                 }
  65.                 ch = 'Y';
  66.             }//检查num是否从小到大排序,成功为Y,不成功为N
  67.             if(ch == 'N')
  68.             {
  69.                 break;
  70.             }//没有正确排序直接进入下一次循环
  71.         }
  72.         */
  73.         ch = 'Y';
  74.         for(int i = 0; i < length - 1; ++i) {
  75.             if(num2[i] > num2[i + 1]) {
  76.                 ch = 'N';
  77.                 break;
  78.             }
  79.         }
  80.         printf("排序后的结果是:");
  81.         for(i = 0;i < length;i ++)
  82.         {
  83.             printf("%d ",num2[i]);
  84.         }
  85.         putchar('\n');
  86.     }while(ch == 'N');

  87.     for(i =0;i <length;i ++)
  88.     {
  89.         printf("我到了结尾!\n");
  90.         array[i] = num2[i];
  91.     }//将排序好的数组放入array
  92. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-5-20 08:49:37 | 显示全部楼层

改成老哥这样确实能运行了,但是想请问下之前我那个判断是否排序成功的两层循环问题出在哪里呢?为什么之前运行那么多次都不能得到'Y'呢?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-5-20 08:52:53 | 显示全部楼层

老哥,我刚刚尝试了一下,把我原本的那两层循环里面的,ch = 'Y'提到了循环开始前也能正常运行了。
为什么ch = 'Y'在循环里面就不能正常呢?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-5-20 08:55:54 | 显示全部楼层

谢谢老哥,我悟了,因为没有重置ch的值,ch第一次循环如果是N值,后面都一直break了
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-5-20 09:02:02 | 显示全部楼层
影影影影影少丶 发表于 2021-5-20 08:52
老哥,我刚刚尝试了一下,把我原本的那两层循环里面的,ch = 'Y'提到了循环开始前也能正常运行了。
为什 ...

载入gdb看一下就知道了
  1. 69                for(i = 0;i < length;i ++)
  2. 1: ch = 78 'N'
  3. (gdb) n
  4. 71                    for(j = 0;j < i;j ++)
  5. 1: ch = 78 'N'
  6. (gdb) print num2
  7. $1 = {73, 108, 111}
  8. (gdb) n
  9. 80                    if(ch == 'N')
  10. 1: ch = 78 'N'
  11. (gdb) n
  12. 82                        break;
  13. 1: ch = 78 'N'
  14. (gdb)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-5-20 09:02:51 | 显示全部楼层
可以看到 ch 一直是 ‘N’,即使顺序是对的,ch 也依然是 ‘N’
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-5-20 10:46:38 | 显示全部楼层
人造人 发表于 2021-5-20 09:02
可以看到 ch 一直是 ‘N’,即使顺序是对的,ch 也依然是 ‘N’

明白了,谢谢老哥^-^
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-6 09:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表