当前位置: 首页 > news >正文

北京南站地铁几号线做网站优化有什么方法

北京南站地铁几号线,做网站优化有什么方法,百度seo不正当竞争秒收,属于公司的网站怎么做第七章 回溯算法 332.重新安排行程51.N皇后37.解数独代码随想录文章详解 332.重新安排行程 (1)参考 创建map存储src,[]dest映射关系,并对[]dest排序 每次取map中第一个dest访问,将其作为新的src,每访问一条src->dest&#xff…

第七章 回溯算法

  • 332.重新安排行程
  • 51.N皇后
  • 37.解数独
  • 代码随想录文章详解

332.重新安排行程

(1)参考
创建map存储src,[]dest映射关系,并对[]dest排序
每次取map中第一个dest访问,将其作为新的src,每访问一条src->dest,删除该记录。
如果访问的src没有dest了,将当前节点加入结果集,并沿栈返回。
结果是沿栈返回的,故需要逆序输出

func findItinerary(tickets [][]string) []string {res := []string{}m := make(map[string][]string, 0)for _, ticket := range tickets {src, dest := ticket[0], ticket[1]m[src] = append(m[src], dest)}for k:= range m {sort.Strings(m[k])}var help func(srcTicket string)help = func(srcTicket string) {for {if v, ok := m[srcTicket]; !ok || len(v) == 0 {break}tmp := m[srcTicket][0]m[srcTicket] = m[srcTicket][1:]help(tmp)}res = append(res, srcTicket)}help("JFK")for i, j := 0, len(res)-1; i < j; i, j = i+1, j-1 {res[i], res[j] = res[j], res[i]}return res
}

(2)回溯:超时了
排列问题。先对tickets排序,used记录当前车票是否被使用
若车票使用完并找到路径,返回,否则回溯查找路径

func findItinerary(tickets [][]string) []string {sort.Slice(tickets, func(i, j int) bool {return tickets[i][1] < tickets[j][1]})path := []string{"JFK"}used := make([]bool, len(tickets))var help func(srcTicket string, ticket [][]string) boolhelp = func(srcTicket string, ticket [][]string) bool {if len(path) == len(tickets)+1 {return true}for i, next := range tickets {if next[0] == path[len(path)-1] && !used[i] {path = append(path, next[1])used[i] = trueif help(next[1], tickets) {return true}path = path[:len(path)-1]used[i] = false}}return false}help("JFK", tickets)return path
}

51.N皇后

回溯
row控制递归深度,for循环控制列,进而确定当前位置
判断当前值是否有效:因为每行只选取一个位置,故只需判断列和正斜、反斜方向是否有皇后

func solveNQueens(n int) [][]string {res := [][]string{}board := make([][]string, n)for i := 0; i < n; i++ {board[i] = make([]string, n)}for i := 0; i < n; i++ {for j := 0; j < n; j++ {board[i][j] = "."}}var help func(row int, board [][]string) boolhelp = func(row int, board [][]string) bool {if row == n {temp := make([]string, n)for i, rowStr := range board {temp[i] = strings.Join(rowStr, "")}res = append(res, temp)}for i := 0; i < n; i++ {if isValid(n, row, i, board) {board[row][i] = "Q"if help(row+1, board) {return true}board[row][i] = "."}}return false}help(0, board)return res
}func isValid(n, row, col int, board [][]string) bool {for i := 0; i < row; i++ {if board[i][col] == "Q" {return false}}for i, j := row-1, col-1; i >= 0 && j >= 0; i, j = i-1, j-1 {if board[i][j] == "Q" {return false}}for i, j := row-1, col+1; i >= 0 && j < n; i, j = i-1, j+1 {if board[i][j] == "Q" {return false}}return true
}

37.解数独

回溯
当前位置有效性判断:行、列、九宫格数字不重复
如果当前位置能放数字,且有效,递归,否则回溯

func solveSudoku(board [][]byte) {var help func(board [][]byte) boolhelp = func(board [][]byte) bool {for i := 0; i < 9; i++ {for j := 0; j < 9; j++ {if board[i][j] == '.' {for k := '1'; k <= '9'; k++ {if isValid(i, j, byte(k), board) {board[i][j] = byte(k)if help(board) {return true}board[i][j] = '.'}}return false}}}return true}help(board)
}func isValid(row, col int, val byte, board [][]byte) bool {for i := 0; i < 9; i++ {if board[row][i] == val {return false}}for i := 0; i < 9; i++ {if board[i][col] == val {return false}}startRow := (row / 3) * 3startCol := (col / 3) * 3for i := startRow; i < startRow+3; i++ {for j := startCol; j < startCol+3; j++ {if board[i][j] == val {return false}}}return true
}

代码随想录文章详解

332.重新安排行程
51.N皇后
37.解数独
回溯总结篇

http://www.yayakq.cn/news/264676/

相关文章:

  • 小企业做网站有没有用永久免费云电脑
  • 做的好的茶叶网站有哪些陈木胜怎么死的
  • 电商网站开发岗位职责html5网站 欣赏
  • 沈阳做网站的公司打电话说帮忙做网站
  • 谷歌没收录网站主页 301重定向北京seo人员
  • 国外网站推广软件源码论坛wordpress模板
  • 如何创办一个网站第三方物流网站建设
  • 个人备案网站放什么资料中国经济网
  • 网站设计 psdwordpress虚拟物品销售
  • 建一个分类信息网站检察院门户网站建设自查报告
  • 360网站怎么做wordpress 仿微博
  • 优酷视频放到网站上怎么做网络会议系统有哪些
  • 国内永久免费crm系统网站推荐大全中南集团中南建设网站
  • wordpress 首页浏览量统计百度快速优化软件
  • 中国建设银行网站特色北理离线《网站开发与应用》
  • 卡片式网站合肥网站建设价格
  • 无锡网站排名优化公司哪家好泉州网站建设 首选猴子网络
  • 想做网站找哪个公司好网站域名设计
  • 注册一个网站要多少费用江苏设计网站电话
  • 365元做网站做一个微信小程序
  • seo网站优化专家住建房官网查询
  • 简约大方自助建站模板Wordpress动静态分离
  • 集团网站 备案大连大家营销
  • phpcms 生成网站地图免费做网站怎么做网站吗2
  • 贵州网站建设设计公司南和信息港
  • 那家网站做的效果好简单网站如何制作
  • 搭建cms网站微信同步wordpress
  • 国内优秀设计网站站长南山商城网站建设多少钱
  • 建设网站用新域名还是老域名国产服务器系统免费的有哪些
  • 昆明网站做深圳罗湖做网站