2021-02-16:n皇后问题。给定一个整数n,返回n皇后的摆法有多少种?
福哥答案2021-02-16:
自然智慧即可。
1.普通递归。有代码。
需要判断同列和斜线。
2.位运算递归。有代码。
3.我的递归。有代码。
只需要判断斜线。
代码用golang编写,代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 | package main import ( "fmt" "time" ) func main() { n := 12 fmt.Println(n, "皇后问题" ) fmt.Println( "------" ) now := time.Now() fmt.Println( "1.普通递归:" , num1(n)) fmt.Println( "时间:" , time.Now().Sub(now)) fmt.Println( "------" ) now = time.Now() fmt.Println( "2.位运算递归:" , num2(n)) fmt.Println( "时间:" , time.Now().Sub(now)) fmt.Println( "------" ) now = time.Now() fmt.Println( "3.我的递归:" , num3(n)) fmt.Println( "时间:" , time.Now().Sub(now)) } func num1(n int) int { if n < 1 { return 0 } record := make([]int, n) return process1(0, record, n) } func process1(i int, record []int, n int) int { if i == n { return 1 } res := 0 for j := 0; j < n; j++ { if isValid(record, i, j) { record[i] = j res += process1(i+1, record, n) } } return res } func isValid(record []int, i int, j int) bool { for k := 0; k < i; k++ { if j == record[k] || abs(record[k]-j) == abs(i-k) { return false } } return true } func abs(a int) int { if a < 0 { return -a } else { return a } } func num2(n int) int { if n < 1 || n > 32 { return 0 } limit := -1 if n != 32 { limit = (1 << n) - 1 } return process2(limit, 0, 0, 0) } func process2(limit int, colLim int, leftDiaLim int, rightDiaLim int) int { if colLim == limit { return 1 } pos := limit & (^(colLim | leftDiaLim | rightDiaLim)) mostRightOne := 0 res := 0 for pos != 0 { mostRightOne = pos & (^pos + 1) pos = pos - mostRightOne res += process2(limit, colLim|mostRightOne, (leftDiaLim|mostRightOne)<<1, (rightDiaLim|mostRightOne)>>1) } return res } func num3(n int) int { rest := make([]int, n) record := make([]int, n) for i := 0; i < n; i++ { rest[i] = i } ansval := 0 ans := &ansval process3(record, 0, rest, ans) return *ans } func process3(record []int, recordLen int, rest []int, ans *int) { restLen := len(rest) if restLen == 0 { *ans++ return } for i := 0; i < restLen; i++ { isValid := true for j := 0; j < recordLen; j++ { //不需要看同行和同列,只需要考虑斜线 if abs(j-recordLen) == abs(record[j]-rest[i]) { isValid = false break } } if isValid { record[recordLen] = rest[i] restCopy := make([]int, restLen) copy(restCopy, rest) restCopy = append(restCopy[:i], restCopy[i+1:]...) process3(record, recordLen+1, restCopy, ans) } } } |
执行结果如下:
***
[左神java代码](https://github.com/algorithmzuo/algorithmbasic2020/blob/master/src/class23/Code03_NQueens.java)
[评论](https://user.qzone.qq.com/3182319461/blog/1613432317)
公众号:福大大架构师每日一题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具