【代码随想录】算法训练计划30

【代码随想录】算法训练计划30

1、51. N 皇后

按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。

n 皇后问题 研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。

给你一个整数 n ,返回所有不同的 n 皇后问题 的解决方案。

每一种解法包含一个不同的 n 皇后问题 的棋子放置方案,该方案中 ‘Q’ 和 ‘.’ 分别代表了皇后和空位。

我写的:

我先想了一个思路,然后去看代码回想录,和我想的一样,我取巧了,直接看了她的写的,不过都理解
但也有一点别的收获
他把res设为了全局变量,这样就连&和*都不需要了

收获:

全局的声明:var res [][]string

函数内初始化:res = [][]string{}

这样就不需要取值操作了——就是&,* 这些个

func solveNQueens(n int) [][]string {
    res := make([][]string, 0)
    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] = "."
        }
    }
    backtrack(board, 0, &res)
    return res
}
func backtrack(board [][]string, row int, res *[][]string) {
    size := len(board)
    //结束条件是到board,就是到最后一行也添加皇后了
    if row == size {
        ans := make([]string, size)
        for i := 0; i < size; i++ {
            ans[i] = strings.Join(board[i], "")
        }
        *res = append(*res, ans)
        return
    }
    for col := 0; col < size; col++ {
        if !isValid(board, row, col){
            continue
        }
        board[row][col] = "Q"
        backtrack(board, row+1, res)
        board[row][col] = "."
    }
}
func isValid(board [][]string, row,col int) (res bool){
    n := len(board)
    //判断这一列上下行是否有Q
    for i := 0; i < row; i++ {
        if board[i][col] == "Q" {
            return false
        }
    }
    //判断这一行左右列是否有Q
    for i := 0; i < col; i++ {
        if board[row][i] == "Q" {
            return false
        }
    }
  	//为什么不判断左下线和右下线的原因很简单,因为下边的行还没有给皇后,所以不需要判断
    //判断左上线是否有Q
    for i, j := row, col; i >= 0 && j >= 0; i, j =  i-1, j-1 {
        if board[i][j] == "Q" {
            return false
        }
    }
    //判断右上线是否有Q
    for i, j := row, col; i >= 0 && j < n; i,j = i-1,j+1 {
        if board[i][j] == "Q" {
            return false
        }
    }
    return true
}
2、37. 解数独

编写一个程序,通过填充空格来解决数独问题。

数独的解法需 遵循如下规则:

数字 1-9 在每一行只能出现一次。
数字 1-9 在每一列只能出现一次。
数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图)
数独部分空格内已填入了数字,空白格用 ‘.’ 表示。

提示:

board.length == 9
board[i].length == 9
board[i][j] 是一位数字或者 ‘.’
题目数据 保证 输入数独仅有一个解

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

我第一次只能写到如下这么多了

//做一个二维的字典或者数组,方便第三个判断,0-02,1-35,2-68或者0-13,1-46,2-79,
jgg := [3][2]{
    {0,2},
    {3,5},
    {6,8},
}
func solveSudoku(board [][]byte)  {
    list := make([]int, 0)
    backtrack(list []int, &board)
    return board
}
func backtrack(board *[][]byte) {
    //到第九行结束,一行一行的填入,每一行要填入9个数字
    //记住,这个数独只有唯一一个解
    if Index == 9 {
        ans := make([]int, len(list))
        copy(ans, list)
        *board
    }
    for i := 0; i <= 9; i++ {
        //我的难点就是不知道怎么去知道这个行,列,然后去嗯...给他整上数字
    }
}

//判断所填入数字是否满足条件
func mz(board *[][]byte, shu,row,col int) bool{
    //左右这个数没出现过,i不变,j变,情况下,可以添加这个数字
    for j := 0; j < 9 ; j++ {
        if board[row][j] == shu {
            return false
        }
    }
    //上下这个数没出现过, i变,j不变
    for i := 0; i < 9; i++ {
        if board[i][col] == shu {
            return false
        }
    }
    //判断他所在区域的9个格子是否出现-除以三-判断是第几个格子
    h := row/3
    l := col/3
    for i := jgg[h][0]; i <= jgg[h][1] {
        for j := jgg[l][0]; j <= jgg[l][1]{
            if board[i][j] == shu {
                return false
            }
        }
    }
    return true
}

看题解理解后如下啊:

思路:

  1. 第一步咱们很清楚的知道,需要判断加入的数是否满足条件,所以写了mz函数,感觉我判断格子的方法有点臃肿了
  2. 好,开始正题,进入backtrack
  3. 为什么这次没有和solveSudoku分开单独写一个呢,在于这个题目人家不要返回值,而且填写的是board,二维的,咱要是在分开的backtrack函数用*[][]int,其实,传不进去单个值,所以直接在solveSudoku函数先声明,再初始化,再使用
    4.好了开始说说初始化,也就是backtrack的主体,首先是这个双重for循环,记得水仙花数,打印图形吗,这类的题目就是用了双重for循环来代表要添加的元素所在的行列
  4. 接着判断不是’.'的不需要变成数字,跳过当前循环,进入下一层
  5. 重重点开始
  6. 首先是’1’-'9’是选择列表,但是因为board是[][]byte类型,在你追加的时候需要类型转换byte(shu),判断是否满足mz的传参也需要
  7. 接着是循环,不过这里用了if,多了一层判断,为真就return true
  8. 接着回溯,都知道
  9. 接着下边又有两个return,说实话,我还不太理解这三个return到底有什么妙用
  10. 关于方格的判断条件啊,还是人家代码随想录写得好,值得看看,不过别担心,不难理解
func solveSudoku(board [][]byte)  {
    var backtrack func(board [][]byte) bool
    backtrack = func(board [][]byte) bool {
        //双重for循环,代表行列
        for  i := 0; i < 9; i++ {
            for j := 0; j < 9; j++ {
                //只有当前位置为.的时候才可以添加数字,否则跳过这个数
                if board[i][j] != '.'{
                    continue
                }
                //重点,填写1-9是选择列表,
                for shu := '1'; shu <= '9'; shu++ {
                    if mz(board,byte(shu),i,j) == true {
                        //追加
                        board[i][j] = byte(shu)
                        //循环
                        if backtrack(board) == true {
                            return true
                        }
                        //回溯
                        board[i][j] = '.'
                    }
                }
                return false
            }
        }
        return true
    }
    backtrack(board)
}
func backtrack(board *[][]byte) {

}

//判断所填入数字是否满足条件
func mz(board [][]byte, shu byte, row,col int) bool {
    //做一个二维的字典或者数组,方便第三个判断,0-02,1-35,2-68或者0-13,1-46,2-79,
    jgg := [3][2]int{
        {0,2},
        {3,5},
        {6,8},
    }
    //左右这个数没出现过,i不变,j变,情况下,可以添加这个数字
    for j := 0; j < 9 ; j++ {
        if board[row][j] == shu {
            return false
        }
    }
    //上下这个数没出现过, i变,j不变
    for i := 0; i < 9; i++ {
        if board[i][col] == shu {
            return false
        }
    }
    //判断他所在区域的9个格子是否出现-除以三-判断是第几个格子
    h := row/3
    l := col/3
    for i := jgg[h][0]; i <= jgg[h][1]; i++ {
        for j := jgg[l][0]; j <= jgg[l][1]; j++{
            if board[i][j] == shu {
                return false
            }
        }
    }
    return true
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/179847.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

部署项目时常用的 Linux 命令

目录 1 前言2 SSH登录命令3 SCP传输命令4 CP拷贝命令5 MV移动命令6 TAR解压命令7 DU查看文件夹/文件大小8 TAIL查看日志9 NOHUP后台运行10 结语 1 前言 在应用部署过程中&#xff0c;Linux命令是必不可少的工具。它们能够帮助我们管理文件、连接服务器、拷贝文件、查看日志以及…

基于SpringBoot的图书管理系统

基于SpringBoot的图书管理系统 图书管理系统开发技术功能模块代码结构数据库设计运行截图源码获取 图书管理系统 开发技术 技术&#xff1a;SpringBoot、MyBatis-Plus、MySQL、Beetl、Layui。 框架&#xff1a;基于开源框架Snowy-Layui开发。 工具&#xff1a;IDEA、Navicat等…

越南服务器租用:企业在越南办工厂的趋势与当地(ERP/OA等)系统部署的重要性

近年来&#xff0c;越南逐渐成为全球企业布局的热门目的地之一。许多企业纷纷选择在越南设立工厂&#xff0c;以利用其低廉的劳动力成本和优越的地理位置。随着企业在越南的扩张&#xff0c;对于当地部署ERP系统或OA系统等的需求也日益增长。在这种情况下&#xff0c;租用越南服…

PTA-矩阵A乘以B

给定两个矩阵A和B&#xff0c;要求你计算它们的乘积矩阵AB。需要注意的是&#xff0c;只有规模匹配的矩阵才可以相乘。即若A有Ra​行、Ca​列&#xff0c;B有Rb​行、Cb​列&#xff0c;则只有Ca​与Rb​相等时&#xff0c;两个矩阵才能相乘。 输入格式&#xff1a; 输入先后…

05 取样器(BeanShell和JSR223 Sampler)

一、取样器作用 1、取样器可以理解为Jmeter的桥梁&#xff0c;或者是Jmeter的加工厂&#xff1b; 2、Jmeter使用过程中&#xff0c;经常有些数据不能直接使用&#xff0c;需要加工后才能使用&#xff1b;这样就用到了取样器&#xff1b;但是这里存在问题&#xff0c;Jmeter中的…

VL06O报表添加增强字段

业务描述 用户需要在VL06O事务代码下进行批量交货过账&#xff0c;现有的筛选条件不太适用当前公司的业务&#xff0c;需要在报表中新增三个交货单增强字段&#xff0c;方便其筛选&#xff08;选择屏幕没有加&#xff0c;用户在报表里用标准按钮功能自己筛选&#xff09; 效果…

FastAPI通过SSE进行流式输出

服务端推送 在服务器推送技术中&#xff0c;服务器在消息可用后立即主动向客户端发送消息。其中&#xff0c;有两种类型的服务器推送&#xff1a;SSE和 WebSocket。 SSE&#xff08;Server-Send Events&#xff09; SSE 是一种在基于浏览器的 Web 应用程序中仅从服务器向客户…

Springboot_文件下载功能(前端后端)

遇到的问题&#xff1a; 文件下载后文件一直被破坏&#xff0c;无法正常打开文件名乱码&#xff0c;如图 刚开始一直在纠结&#xff0c;是不是后端没有写对&#xff0c;然后导致下载不能使用 后来搜索了一些资料&#xff0c;发现后端没什么问题 然后就开始找到其他项目对比…

趋势解读:TikTok独创的社交语言是如何演变的

在数字时代的浪潮中&#xff0c;社交媒体平台成为人们传递信息、表达创意和建立社交联系的重要场所。而在这众多社交平台中&#xff0c;TikTok以其独特的社交语言和创新的内容形式&#xff0c;迅速吸引了全球数以亿计的用户。本文将深入探讨TikTok的社交语言是如何独创并演变的…

史上最细教程-一台服务器上搭建2个MySQL实例

史上最细教程-一台服务器上搭建2个MySQL实例 文章目录 史上最细教程-一台服务器上搭建2个MySQL实例环境准备&#xff1a;操作步骤&#xff1a;1.安装MySQL2.配置搭建3306、3307实例3.初始化3306、3307实例、远程连接访问支持 环境准备&#xff1a; 服务器&#xff1a;阿里云Ce…

Redis主从,缓存击穿,雪崩,哨兵等问题

Redis的性能管理&#xff1a; Redis的数据缓存在内存当中 INFO memory used_memory:853808 Redis中数据占用的内存 used_memory_rss:3715072 Redis向操作系统申请的内容 used_memory_peak:853808 Redis使用的内存的峰值 系统巡检&#xff1a;硬件巡检&#xff0c;数据库…

图像分类原理

一、什么是图像分类(Image Classification) 图像分类任务是计算机视觉中的核心任务&#xff0c;其目标是根据图像信息中所反映的不同特征&#xff0c;把不同类别的图像区分开来。 二、图像分类任务的特点 对于人来说&#xff0c;完成上述的图像分类任务简直轻而易举&#xf…

YOLOV5标注训练自己的数据全流程教程

概述 yolo在目标检测领域是非常有代表性的模型&#xff0c;它速度快识别效果也很精准&#xff0c;是实时检测模型中应用最广泛的。yolo的原理和代码是很容易获得的&#xff0c;且有各式各样的教程&#xff0c;但是模型怎么使用的教程相对比较少。本文讲解如何使用yolov5模型训…

java.lang.IllegalStateException: Can not add resource

安卓解决 java.lang.IllegalStateException: Can not add resource 放两个链接 解决Can not add resource (com.android.aaptcompiler.ParsedResourcea980fbb) to table_言并肃的博客-CSDN博客 android attr何时会冲突_android attr冲突-CSDN博客 然后去新增的依赖找资源…

详解——菱形继承及菱形虚拟继承

目录 一&#xff0c;菱形继承 1.1单继承 1.2多继承 1.3菱形继承 1.4菱形继承的问题 1.5虚拟继承解决数据冗余和二义性的原理 二.继承的总结和反思 一&#xff0c;菱形继承 C三大特性——继承-CSDN博客 1.1单继承 单继承&#xff1a;一个子类只有一个直接父类时称这个继…

合伙人注册即得/创业平台扶持!

问心一语持续体验中~ 与公司签订线下&#xff08;线上&#xff09;纸质合伙人代理合同&#xff0c;具备法律效力。 一级直推、非一级直推注册即得奖励。(消耗完毕被邀请用户赠送的AI免费使用条数) 即&#xff1a;邀请1人注册即得并消耗&#xff01;只需注册无需充值&#xff…

2023年度openGauss标杆应用实践案例征集

标杆应用实践案例征集 2023 openGauss 数据库作为企业IT系统的核心组成部分&#xff0c;是数字基础设施建设的关键&#xff0c;是实现数据安全稳定的保障。openGauss顺应开源发展趋势&#xff0c;强化核心技术突破&#xff0c;着力打造自主根社区&#xff0c;携手产业伙伴共同…

单片机语音芯片开发要解决的问题

在单片机语音芯片开发过程中&#xff0c;可能会遇到多种问题&#xff0c;这些问题可能来自于技术层面&#xff0c;也可能来自于芯片本身的设计和应用层面。下面让我们具体从芯片的功耗、语音识别的准度、芯片的尺寸和芯片的可靠性四个方面开展讨论。 1.芯片的功耗问题 首先&a…

干货分享 | 一分钟带你了解TSMaster小程序编辑代码智能提示功能

本文给大家带来TSMaster小程序编辑的新功能&#xff0c;其中主要包含&#xff1a;代码编辑智能提示功能、可用外部代码编辑器编辑小程序代码并同步。 本文关键字&#xff1a;C小程序、Python小程序、代码智能提示、外部代码编辑器、Visual Studio 目录/Catalog ● TSMaster的…

【网络】数据链路层协议

数据链路层协议 一、链路层解决的问题二、以太网协议1、局域网技术2、令牌环网&#xff08;了解&#xff09;3、以太网通信原理4、 MAC地址5、以太网帧格式6、碰撞避免7、最大传输单元MTU 二、ARP协议1、ARP数据的格式2、ARP协议的工作流程3、ARP缓存表4、ARP协议中的一些问题7…