22.回溯算法4

news2025/2/24 6:32:36

递增子序列

这里不能排序,因为数组的顺序是对结果有影响的,所以只能通过used数组来去重

class Solution {
public:
    vector<int> path;
    vector<vector<int>> res;
    void backtracking(vector<int>& nums,int start){
        if(path.size()>1)
        res.push_back(path);
        int used[201]={0};
        for(int i=start;i<nums.size();i++){
           
            if(path.empty()||nums[i]>=path[path.size()-1]){
                if(used[nums[i]+100])continue;;
                path.push_back(nums[i]);
                used[nums[i]+100]=1;
                backtracking(nums,i+1);
                path.pop_back();
                
            }
        }
    }
    vector<vector<int>> findSubsequences(vector<int>& nums) {
        backtracking(nums,0);
        return res;
    }
};

全排列

class Solution {
public:
    vector<int> path;
    vector<vector<int>> res;
    int* used;
    int level=0;
    void backtracking(vector<int>& nums){
        if(level==nums.size()){
            res.push_back(path);
            return;
        }
        for(int i=0;i<nums.size();i++){
            if(used[i])continue;
            path.push_back(nums[i]);
            level++;
            used[i]=1;
            backtracking(nums);
            path.pop_back();
            used[i]=0;
            level--;
            
        }
        
    }
    vector<vector<int>> permute(vector<int>& nums) {
        used= new int[nums.size()]{0};
        backtracking(nums);
        return res;
    }
};

全排列2

class Solution {
public:
    vector<int> path;
    vector<vector<int>> res;
    int* used;
    int level=0;
    void backtracking(vector<int>& nums){
        if(level==nums.size()){
            res.push_back(path);
            return;
        }
        int pre=20040503;
        for(int i=0;i<nums.size();i++){
            if(used[i])continue;
            if(nums[i]==pre)continue;
            path.push_back(nums[i]);
            level++;
            used[i]=1;
            pre=nums[i];
            backtracking(nums);
            path.pop_back();
            used[i]=0;
            level--;
            
        }
        
    }
    vector<vector<int>> permuteUnique(vector<int>& nums) {
        used= new int[nums.size()]{0};
        sort(nums.begin(),nums.end());
        backtracking(nums);
        
        return res;
    }
};

重新安排行程

class Solution {
    public:
    unordered_map<string,map<string,int>> targets;
    vector<string> res; 
    int tiknum;
    vector<string> backtracking(int stop,string start){
        if(stop==tiknum)return res;
        vector<string> tmp;
        for(auto it:targets[start]){
            if(it.second){
                res.push_back(it.first);
                targets[start][it.first]--;
            }
            else continue;
            tmp=backtracking(stop+1,it.first);
            if(!tmp.empty())return tmp;
            res.pop_back();
            targets[start][it.first]++;
        }
        return tmp;
    }
    vector<string> findItinerary(vector<vector<string>>& tickets) {
        for(auto tick:tickets){
            targets[tick[0]][tick[1]]++;
        }
        tiknum=tickets.size();
        res.push_back("JFK");
        return backtracking(0,"JFK");
    }
};

N皇后

class Solution {
public:
    vector<string> tmp;
    vector<vector<string>> res;
    int n;
    bool isConf(int y,int x){
        for(int i=1;i<=y;i++){
            if(tmp[y-i][x]=='Q')return 1;
            if(x+i<n&&tmp[y-i][x+i]=='Q')return 1;
            if(x-i>=0&&tmp[y-i][x-i]=='Q')return 1;
        }
        return 0;
    }
    void backtracking(int k){
        if(k==n){
            res.push_back(tmp);
        }
        for(int i=0;i<n;i++){
            if(isConf(k,i))continue;
            tmp[k][i]='Q';
            backtracking(k+1);
            tmp[k][i]='.';
        }
    }
    vector<vector<string>> solveNQueens(int n0) {
        n=n0;
        tmp.resize(n);
        for(int i=0;i<n;i++){
            tmp[i].resize(n);
            for(int j=0;j<n;j++){
                tmp[i][j]='.';
            }
        }
        backtracking(0);
        return res;    
    }
};
  • 时间复杂度: O(n!)
  • 空间复杂度: O(n)

解数独

class Solution {
public:
    
    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++) { // 判断9方格里是否重复
        for (int j = startCol; j < startCol + 3; j++) {
            if (board[i][j] == val ) {
                return false;
            }
        }
    }
    return true;
}
    bool backtracking(int x,int y,vector<vector<char>>& board){
        int n=board.size();
        if(x>=n){
            x=x%n;
            y++;
            
        }
        while(x<n&&y<n){
            if(board[y][x]!='.'){
                x++;
                if(x>=n){
                    x=x%n;
                    y++;
                    
                }
                continue;
            }
            for(int i=1;i<10;i++){
                if(!isValid(y,x,i+'0',board))continue;
                board[y][x]=i+'0';           
                if(backtracking(x+1,y,board))return 1;
                board[y][x]='.';
            }
            return 0;
        }
        return 1;
    }
    void solveSudoku(vector<vector<char>>& board) {
        backtracking(0,0,board);
    }
};

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

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

相关文章

第4章 信息系统架构(三)

4.3 应用架构 应用架构的主要内容是规划出目标应用分层分域架构&#xff0c;根据业务架构规划目标应用域、应用组和目标应用组件&#xff0c;形成目标应用架构逻辑视图和系统视图。从功能视角出发&#xff0c;阐述应用组件各自及应用架构整体上&#xff0c;如何实现组织的高阶…

一周学会Flask3 Python Web开发-flask3模块化blueprint配置

锋哥原创的Flask3 Python Web开发 Flask3视频教程&#xff1a; 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 我们在项目开发的时候&#xff0c;多多少少会划分几个或者几十个业务模块&#xff0c;如果把这些模块的视图方法都写在app.py…

Android开发-深入解析Android中的AIDL及其应用场景

深入解析 Android 中的 AIDL 及其应用场景 1. 前言2. AIDL 的核心概念3. AIDL 的实现步骤3.1. 定义 AIDL 接口文件3.2. 实现服务端&#xff08;Service&#xff09;3.3. 客户端绑定与调用 4. AIDL 的典型应用场景4.1. 多进程应用4.2. 与系统服务交互4.3. 高性能 IPC4.4. 跨应用…

基于python的旅客游记和轨迹分析可视化系统设计(新)

项目地址&#xff1a;基于python旅客游记和轨迹分析可视化系统设计&#xff08;新&#xff09; 摘 要 旅客游记和轨迹分析可视化系统是一种能自动从网络上收集信息的工具&#xff0c;可根据用户的需求定向采集特定数据信息的工具&#xff0c;本项目通过研究爬取微博网来实现旅…

HackTheBox靶场之Unrested 漏洞CVE-2024-42327 《CUser 类中的 user.get 函数中的 SQL 注入》

目录 信息收集 web指纹收集 wappazer Nmap指纹收集 Nmap分析总结 漏洞利用 漏洞CVE-POC执行流程 信息收集 web指纹收集 wappazer 看着有apache2.4.52 那么可以试着找一下 apache的历史cve看可以利用否 使用用户名密码&#xff1a;matthew / 96qzn0h2e1k3 登录成后后…

uniprot系列相关数据库介绍

https://www.uniprot.org/uniprotkb/P49711/entry#family_and_domains 上面是一个CTCF human蛋白质条目&#xff0c; 我们来看看family & domain条目中涉及到的蛋白质家族以及结构域数据库&#xff1a; 1&#xff0c;funfam&#xff1a; CATH: Protein Structure Classi…

基于AIGC的图表自动化生成工具「图表狐」深度评测:如何用自然语言30秒搞定专业级数据可视化?

一、工具核心定位&#xff1a;自然语言驱动的数据可视化 作为数据科学从业者&#xff0c;我们常面临非技术同事的图表制作需求。传统流程需经历数据清洗→结构转换→图表配置→样式调整四大阶段&#xff0c;耗时且易出错。 图表狐&#xff08;官网预览&#x1f447;&#xff…

rpc到自己java实现rpc调用再到rpc框架设计

目录 rpc(Remote Procedure Call)rpc一般架构为什么要引入rpc自己实现rpc调用1. 新建一个maven项目&#xff0c;加入hessian依赖2. 服务端3. Stub代理4. 客户端测试输出5. rpc程序分析附 请求参数和序列化程序 6. 总结 回顾RPCRPC 序列化协议RPC 网络协议注册中心的引入dubbo框…

Milvus向量数据库可视化客户端Attu

概述 关于Milvus的介绍&#xff0c;可搜索网络资料。Milvus的使用还在摸索中&#xff1b;打算写一篇&#xff0c;时间待定。 关于Attu的资料&#xff1a; 官网GitHub文档 对于Milvus的数据可视化&#xff0c;有如下两个备选项&#xff1a; Milvus_cli&#xff1a;命令行工…

【落羽的落羽 数据结构篇】顺序结构的二叉树——堆

文章目录 一、堆1. 概念与分类2. 结构与性质3. 入堆4. 出堆 二、堆排序三、堆排序的应用——TOP-K问题 一、堆 1. 概念与分类 上一期我们提到&#xff0c;二叉树的实现既可以用顺序结构&#xff0c;也可以用链式结构。本篇我们来学习顺序结构的二叉树&#xff0c;起个新名字—…

基于STM32的智能农业大棚环境控制系统

1. 引言 传统农业大棚环境调控依赖人工经验&#xff0c;存在控制精度低、能耗高等问题。本文设计了一款基于STM32的智能农业大棚环境控制系统&#xff0c;通过多参数环境监测、作物生长模型与精准执行控制&#xff0c;实现大棚环境的智能优化&#xff0c;提高作物产量与品质。…

Git常见命令--助力开发

git常见命令&#xff1a; 创建初始化仓库&#xff1a; git 将文件提交到暂存区 git add 文件名 将文件提交到工作区 git commit -m "注释&#xff08;例如这是发行的版本1&#xff09;" 文件名 查看状态 如果暂存区没有文件被提交显示&#xff1a; $ git status On…

一:将windows上的Python项目部署到Linux上,并使用公网IP访问

windows中python的版本&#xff1a;python3.13.1&#xff0c;项目使用的是虚拟环境解释器 linux系统&#xff1a;仅有python3.6.7 服务器&#xff1a;阿里云服务器有公网IP&#xff0c;访问端口XXXX 在linux上安装python3.13.1 linux中如果是超级管理员root&#xff0c;执行所…

【数据标准】数据标准化是数据治理的基础

导读&#xff1a;数据标准化是数据治理的基石&#xff0c;它通过统一数据格式、编码、命名与语义等&#xff0c;全方位提升数据质量&#xff0c;确保准确性、完整性与一致性&#xff0c;从源头上杜绝错误与冲突。这不仅打破部门及系统间的数据壁垒&#xff0c;极大促进数据共享…

计算机视觉:经典数据格式(VOC、YOLO、COCO)解析与转换(附代码)

第一章&#xff1a;计算机视觉中图像的基础认知 第二章&#xff1a;计算机视觉&#xff1a;卷积神经网络(CNN)基本概念(一) 第三章&#xff1a;计算机视觉&#xff1a;卷积神经网络(CNN)基本概念(二) 第四章&#xff1a;搭建一个经典的LeNet5神经网络(附代码) 第五章&#xff1…

七星棋牌顶级运营产品全开源修复版源码教程:6端支持,200+子游戏玩法,完整搭建指南(含代码解析)

棋牌游戏一直是移动端游戏市场中极具竞争力和受欢迎的品类&#xff0c;而七星棋牌源码修复版无疑是当前行业内不可多得的高质量棋牌项目之一。该项目支持 6大省区版本&#xff08;湖南、湖北、山西、江苏、贵州&#xff09;&#xff0c;拥有 200多种子游戏玩法&#xff0c;同时…

编程考古-忘掉它,Delphi 8 for the Microsoft .NET Framework

忘掉它吧&#xff0c;作一篇记录&#xff01; 【圣何塞&#xff0c;加利福尼亚 – 2003年11月3日】在今日的Borland开发者大会上&#xff0c;Borland正式推出了Delphi 8 for Microsoft .NET Framework。这款新版本旨在为Delphi开发者提供一个无缝迁移路径&#xff0c;将现有的…

[通俗易懂C++]:指针和const

之前的文章有说过,使用指针我们可以改变指针指向的内容(通过给指针赋一个新的地址)或者改变被保存地址的值(通过给解引用指针赋一个新值): int main() {int x { 5 }; // 创建一个整数变量 x&#xff0c;初始值为 5int* ptr { &x }; // 创建一个指针 ptr&#xff0c;指向 …

大一高数(上)速成:导数和微分

目录 1.分段函数的可导性&#xff1a; 2.隐函数求导: 3.参数方程求导: 4.对数求导法: 5.函数的微分: 1.分段函数的可导性&#xff1a; 2.隐函数求导: 3.参数方程求导: 4.对数求导法: 5.函数的微分:

京东cfe滑块 分析

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 逆向分析 headers {"accept&qu…