鱼C论坛

 找回密码
 立即注册
查看: 3110|回复: 4

[技术交流] 函数递归实现全排列解决国际象棋八皇后问题

[复制链接]
发表于 2016-11-8 18:18:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 致年轻的我们 于 2016-11-8 18:43 编辑

问题引入:国际象棋的八皇后问题。
在国际象棋中,“皇后”可以吃掉与自己同一条横行,纵行或斜线上的棋子,现在在8x8的国际象棋棋盘上放置八个“皇后”,使得任何一个“皇后”都无法直接吃掉其他的“皇后”,因此,任意两个“皇后”都不能处于同一条横行,纵行或斜线上。使用编程计算共有多少种棋子摆放的方式?
实现代码如下,主要运用了函数递归实现数字全排列的方法,代码作者:望尘11,本人感觉不错,摘抄分享给大家。
  1. /************
  2. ***望尘11***
  3. ************/
  4. #include <stdio.h>
  5. #include <string.h>
  6. #include <stdlib.h>
  7. #include <math.h>

  8. void fun(int array[],int len,int pos1);
  9. //void printArray(int array[],int len);
  10. void printRect(int array[8]);
  11. int number=0;

  12. int main()
  13. {
  14.         printf("start\n");
  15.         int array[]={0,1,2,3,4,5,6,7};
  16.         fun(array,sizeof(array)/sizeof(int),0);
  17.         printf("共有以上%d种方案\n",number);
  18.         printf("end\n");
  19.         return 0;
  20. }

  21. int isRight(int array[8])
  22. {
  23.         int i,j;
  24.         for(i=0;i<8;i++)
  25.         {
  26.                 for(j=0;j<8;j++)
  27.                 {
  28.                         if(i!=j)
  29.                         {
  30.                                 if(abs(i-j)==abs(array[i]-array[j]))
  31.                                         return 0;
  32.                         }
  33.                 }
  34.         }
  35.         return 1;
  36. }

  37. void fun(int array[],int len,int pos1)
  38. {
  39.         int i;
  40.         if(pos1>=len-1)
  41.         {
  42.                 if(isRight(array))
  43.                 {
  44.                         number++;
  45.                         //printArray(array,len);
  46.                         printRect(array);
  47.                 }
  48.         }
  49.         else
  50.         {
  51.                 for(i=pos1;i<len;i++)
  52.                 {
  53.                         int temp;
  54.                         temp=array[pos1];
  55.                         array[pos1]=array[i];
  56.                         array[i]=temp;
  57.                        
  58.                         fun(array,len,pos1+1);
  59.                        
  60.                         temp=array[pos1];
  61.                         array[pos1]=array[i];
  62.                         array[i]=temp;
  63.                 }
  64.         }
  65. }

  66. //void printArray(int array[],int len)
  67. //{
  68. //        int i;
  69. //        for(i=0;i<len;i++)
  70. //        {
  71. //                printf("%d\t",array[i]);
  72. //        }
  73. //        printf("\n");
  74. //}

  75. void printLine(int n)
  76. {
  77.         int i=0;
  78.         for(i=0;i<8;i++)
  79.         {
  80.                 printf("%s",n==i?"○":"口");
  81.         }
  82.         printf("\n");
  83. }

  84. void printRect(int array[8])
  85. {
  86.         int i=0;
  87.         for(i=0;i<8;i++)
  88.         {
  89.                 printLine(array[i]);
  90.         }
  91.         printf("\n");
  92. }
复制代码

如果你有方法更好,效率更高的代码,欢迎分享回复。
分享一个编程交流群,不犯规吧:快写代码官方群:136898517
犯规通知我,我会删除,谢谢。
这是我的第一个帖子,多多支持。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-11-8 18:21:35 | 显示全部楼层
1楼
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-11-8 21:21:24 | 显示全部楼层
拿走回复。。文明留贴
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2016-11-9 17:25:26 | 显示全部楼层
递归是神递归是神~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2019-3-22 19:03:12 | 显示全部楼层
拿走回复,文明学习
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-18 21:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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