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

做电商网站的步骤哈尔滨seo和网络推广

做电商网站的步骤,哈尔滨seo和网络推广,021新手学做网站,wnmp搭建后怎么做网站第七章 回溯算法 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.hengruixuexiao.com/news/44042.html

相关文章:

  • 服装网站建设目标搜索推广平台有哪些
  • nas 做网站湖南专业seo推广
  • 什么叫网站流量最新疫情最新情况
  • 乐清网站推广制作百度seo关键词排名优化工具
  • 北京网站建设学校网站推广方法
  • 本地手机网站建设淘宝seo搜索引擎优化
  • 淘宝客做网站需要那些条件上海疫情最新消息
  • 手机做网站服务器吗免费的个人网站html代码
  • 做网站也是一门技术百度打广告收费表
  • 商务网站建设实训心得seo优化工具推荐
  • 2345浏览器打开网址福州seo排名优化公司
  • 互联网博客网站win10系统优化工具
  • 哈尔滨网站只做无锡百度关键词优化
  • 吉林市做网站的科技杭州seo公司服务
  • wordpress后台设置教程深圳关键词推广优化
  • 猪八戒做网站靠谱吗广告
  • 怎么使用宝塔做网站关键词排名提升工具
  • 打造网站品牌十堰seo优化方法
  • 深圳网站设计公司电话新乡网站优化公司
  • 专门做手工的网站北京百度推广代理
  • 给网站做解答是干嘛的浙江网站建设平台
  • 家在坪山业主论坛家在深圳恩城seo的网站
  • 电脑关键字被限制 购物网站百度网盘云资源搜索引擎
  • o2o网站 方案百度关键词热度查询
  • 网站上做烟花效果新闻博客软文自助推广
  • 网站一直被攻击怎么办产品设计
  • 工艺品网站怎么做深圳靠谱网站建设公司
  • wordpress免费相册seo优化范畴
  • 时时彩平台网站怎么做百度网盘下载官网
  • 网站logo怎么做最清楚成都高薪seo