代码随想录刷题第30天

明天就是大年三十了,首先祝各位朋友新年快乐,新春愉快!巧合的是,今天正好是回溯章节的收尾,这也是辞旧迎新的好兆头。

第一题是重新安排行程https://leetcode.cn/problems/reconstruct-itinerary/description/,一道难题,确实有点超出自己的能力就看看题解抄一遍代码ac了。相当于抄了一遍答案哈哈

class Solution {
public:unordered_map<string, map<string, int>> targets;bool backtracking(int ticketNum, vector<string>& result){if (result.size() == ticketNum + 1) return true;for (pair<const string, int>& targets : targets[result[result.size() - 1]]){if (targets.second > 0){result.push_back(targets.first);targets.second--;if (backtracking(ticketNum, result)) return true;result.pop_back();targets.second++;}}return false;}vector<string> findItinerary(vector<vector<string>>& tickets) {vector<string> result;for (const vector<string>& vec : tickets){targets[vec[0]][vec[1]]++;}result.push_back("JFK");backtracking(tickets.size(), result);return result;}
};

第二题是大名鼎鼎的N皇后问题https://leetcode.cn/problems/n-queens/description/,直接上卡哥题解。思路并不难懂,通过每行遍历,将列依次放入皇后,向下一行递归,并调用isValid函数判断合法性,若当前位置合法,则放入皇后。

class Solution {
public:vector<vector<string>> result;void backtracking(int n, int row, vector<string>& chessboard){if (row == n){result.push_back(chessboard);return;}for (int col = 0; col < n; col++){if (isValid(row, col, chessboard, n)){chessboard[row][col] = 'Q';backtracking(n, row + 1, chessboard);chessboard[row][col] = '.';}}}bool isValid(int row, int col, vector<string>& chessboard, int n){for (int i = 0; i < n; i++){if (chessboard[i][col] == 'Q') return false;}for (int i = row - 1, j = col - 1; i >= 0 && j >= 0; i--, j--){if (chessboard[i][j] == 'Q') return false;}for (int i = row - 1, j = col + 1; i >= 0 && j < n; i--, j++){if (chessboard[i][j] == 'Q') return false;}return true;}vector<vector<string>> solveNQueens(int n) {std::vector<std::string> chessboard(n, std::string(n, '.'));backtracking(n, 0, chessboard);return result;}
};

第三题是解数独https://leetcode.cn/problems/sudoku-solver/,作为回溯章节的压轴题,与其他题目最大的不同就是该题需要两个for循环确定一个点。

class Solution {
public:bool backtracking(vector<vector<char>>& board){for (int i = 0; i < board.size(); i++){//行遍历for (int j = 0; j < board[0].size(); j++){//列遍历if (board[i][j] != '.') continue;for (char k = '1'; k <= '9'; k++){if (isValid(i, j, k, board)){board[i][j] = k;if(backtracking(board)) return true;board[i][j] = '.';}}return false;}}return true;}bool isValid(int row, int col, char val, vector<vector<char>>& board){for (int i =0; i < 9; i++){if (board[row][i] == val) return false;}for (int j = 0; j < 9; j++){if (board[j][col] == val) return false;}int startRow = (row / 3) * 3;int startCol = (col / 3) * 3;for (int i = startRow; i < startRow + 3; i++){for (int j = startCol; j < startCol + 3; j++){if (board[i][j] == val) return false;}}return true;}void solveSudoku(vector<vector<char>>& board) {backtracking(board);}
};

刷完了回溯,给我的感觉是回溯像一个已经有框架的楼房,只需要在某些部分上添加东西。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

生产者-消费者模式什么?使用场景深度解析!

前言 大家好&#xff0c;我是chowley&#xff0c;祝大家三十快乐&#xff0c;今天总结一下我之前在项目中使用过的生产者-消费者模式。 生产者-消费者模式&#xff08;Producer-Consumer Pattern&#xff09;是一种经典的并发编程模式&#xff0c;用于解决生产者和消费者之间…

Kubernetes与Docker的深入对比:解析容器编排与容器引擎的区别与联系

Kubernetes与Docker的深入对比&#xff1a;解析容器编排与容器引擎的区别与联系 引言 容器技术的崛起为软件开发和部署带来了革命性的变化。在这个领域&#xff0c;Kubernetes&#xff08;简称K8s&#xff09;和Docker是两个备受瞩目的技术&#xff0c;但它们之间有着明显的区…

深度学习入门笔记(八)可以不断思考的模型:RNN与LSTM

8.1 循环神经网络RNN 之前学到的 CNN 和全连接&#xff0c;模型的输入数据之间是没有关联的&#xff0c;比如图像分类&#xff0c;每次输入的图片与图片之间就没有任何关系&#xff0c;上一张图片的内容不会影响到下一张图片的结果。但在自然语言处理领域&#xff0c;这就成了…

spring boot(2.4.x 开始)和spring cloud项目中配置文件application和bootstrap加载顺序

在前面的文章基础上 https://blog.csdn.net/zlpzlpzyd/article/details/136060312 spring boot 2.4.x 版本之前通过 ConfigFileApplicationListener 加载配置 https://github.com/spring-projects/spring-boot/blob/v2.3.12.RELEASE/spring-boot-project/spring-boot/src/mai…

机器学习之T与F分布

T分布 T分布:数学期望为mu=0,方差: σ 2 = n n − 2 ( n > 2 ) \sigma^2=\frac{n}{n-2} \quad (n>2) σ2=n−2n​(n>2)。相同自由度情况下,|t|越大,概率P越小; 设X~N(0,1),Y~χ2(n),并且X和Y独立,则称随机变量 t = X Y n t=\frac{X}{\sqrt{\frac{Y…

Redis Centos7 安装到启动

文章目录 安装Redis启动redis查看redis状况连接redis服务端 安装Redis 1.下载scl源 yum install centos-release-scl-rh2.下载redis yum install rh-redis5-redis 3. 创建软连接 1.cd /usr/bin 2. In -s /opt/rh/rh-redis5/root/usr/bin/redis-server ./redis-server 3. …

【RT-DETR进阶实战】利用RT-DETR进行过线统计(可用于人 、车过线统计)

👑欢迎大家订阅本专栏,一起学习RT-DETR👑 一、本文介绍 Hello,各位读者,最近会给大家发一些进阶实战的讲解,如何利用RT-DETR现有的一些功能进行一些实战, 让我们不仅会改进RT-DETR,也能够利用RT-DETR去做一些简单的小工作,后面我也会将这些功能利用PyQt或者是p…

机器学习系列——(十九)层次聚类

引言 在机器学习和数据挖掘领域&#xff0c;聚类算法是一种重要的无监督学习方法&#xff0c;它试图将数据集中的样本分组&#xff0c;使得同一组内的样本相似度高&#xff0c;不同组间的样本相似度低。层次聚类&#xff08;Hierarchical Clustering&#xff09;是聚类算法中的…

幻兽帕鲁服务器创建私服教程(新版教程更简单)

幻兽帕鲁官方服务器不稳定&#xff1f;自己搭建幻兽帕鲁服务器&#xff0c;低延迟、稳定不卡&#xff0c;目前阿里云和腾讯云均推出幻兽帕鲁专用服务器&#xff0c;腾讯云直接提供幻兽帕鲁镜像系统&#xff0c;阿里云通过计算巢服务&#xff0c;均可以一键部署&#xff0c;鼠标…

项目02《游戏-07-开发》Unity3D

基于 项目02《游戏-06-开发》Unity3D &#xff0c; 接下来做UI框架的逻辑系统&#xff0c;管理器和UI背包&#xff0c; 首先闯将UI框架的两个重要脚本 BasePanel.cs 和 UIManager.cs &#xff0c; 双击BasePanel.cs脚本修改代码&#xff1a; using UnityEngine; pu…

【java苍穹外卖项目实战一】苍穹外卖项目介绍

文章目录 1、项目介绍1、项目概述2、 产品原型3、技术选型 1、项目介绍 在开发苍穹外卖这个项目之前&#xff0c;我们需要全方位的来介绍一下当前我们学习的这个项目。接下来&#xff0c;我们将从项目简介、产品原型、技术选型三个方面来介绍苍穹外卖这个项目。 1、项目概述 …

绝缘栅极晶体管IGBT

IGBT&#xff08;绝缘栅极晶体管&#xff09;: 常用于百V百A级使用&#xff0c;外观上看相比于MOS最大的区别是比较大&#xff0c;mos主要用于中小功率器件中。 本质是一个电子开关&#xff0c;相比于MOS和三极管来说其最大的特点是耐压很高&#xff0c;可达6000V以上&#xf…

第十四章 以编程方式使用 SQL 网关 - %SQLGatewayConnection 方法和属性

文章目录 第十四章 以编程方式使用 SQL 网关 - %SQLGatewayConnection 方法和属性AllocateStatement()Connect()ConnectionHandle propertyDisconnect()DLLHandle 属性DLLName 属性DSN 属性 第十四章 以编程方式使用 SQL 网关 - %SQLGatewayConnection 方法和属性 AllocateSta…

【LeetCode每日一题】525连续数组 303区域和检索(前缀和的基本概念和3个简单案例)

前缀和 // 构造prefix let prefix [0] arr.forEach(num > {prefix.push(prefix.at(-1) num); })如果想要计算某个区间 i 到 j 这个子数组的和时&#xff0c;可以根据 prefix[j1] - prefix[i] 获得。 例题1&#xff1a;303.区域和检索 - 数组不可变 给定一个整数数组 num…

【开源】SpringBoot框架开发考研专业课程管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 考研高校模块2.3 高校教师管理模块2.4 考研专业模块2.5 考研政策模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 考研高校表3.2.2 高校教师表3.2.3 考研专业表3.2.4 考研政策表 四、系统展示五、核…

npm---设置淘宝镜像时报“certificate has expired“的错误

今天使用vue create my-app 创建项目时&#xff0c;竟然报错&#xff1a; Error: Command failed: npm info vue-cli-version-marker --json --registryhttps://registry.npm.taobao.org npm ERR! code CERT_HAS_EXPIRED npm ERR! errno CERT_HAS_EXPIRED npm ERR! request t…

c语言中的模拟多态性

在C语言中模拟多态性 多态性是面向对象编程中的一个核心概念&#xff0c;它允许我们通过一个共同的接口来操作不同的数据类型。虽然C语言是一种过程式语言&#xff0c;本身不直接支持面向对象的特性&#xff0c;如继承、封装和多态&#xff0c;但我们可以通过一些技巧来模拟这些…

MinIO数据迁移

使用 Docker 运行 MinIO 客户端&#xff08;mc&#xff09;来进行 MinIO 服务器之间的数据迁移。这里是一步步的解析和说明&#xff1a; 拉取 MinIO 客户端 Docker 镜像: docker pull minio/mc这一步会从 Docker Hub 上拉取最新的 MinIO 客户端&#xff08;mc&#xff09;镜像。…

算法之双指针系列1

目录 一&#xff1a;双指针的介绍 1&#xff1a;快慢指针 2&#xff1a;对撞指针 二&#xff1a;对撞指针例题讲述 一&#xff1a;双指针的介绍 在做题中常用两种指针&#xff0c;分别为对撞指针与快慢指针。 1&#xff1a;快慢指针 简称为龟兔赛跑算法&#xff0c;它的基…

机器学习11-前馈神经网络识别手写数字1.0

在这个示例中&#xff0c;使用的神经网络是一个简单的全连接前馈神经网络&#xff0c;也称为多层感知器&#xff08;Multilayer Perceptron&#xff0c;MLP&#xff09;。这个神经网络由几个关键组件构成&#xff1a; 1. 输入层 输入层接收输入数据&#xff0c;这里是一个 28x…