蓝桥杯打卡Day1


文章目录

  • 全排列
  • 八皇后

一、全排列IO链接

**本题思路:**本题是一道经典的全排列问题,深度优先搜索即可解决。

cpp 复制代码
#include <bits/stdc++.h>

constexpr int N=10;

std::string s;
std::string ans;
int n;
bool st[N];

void dfs(int u)
{
    if(u==n)
    {
        std::cout<<ans<<std::endl;
        return;
    }
    
    for(int i=0;i<n;i++){
        //如果当前字符没有遍历过,则加入到当前的字符串中去
        if(!st[i]){
            st[i]=true;
            ans.push_back(s[i]);
            dfs(u+1);//继续寻找下一个满足条件的字符
            ans.pop_back();//回溯
            st[i]=false;
        }
    }
}

int main()
{
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);std::cout.tie(nullptr);
    
    std::cin>>s;
    n=s.size();
    dfs(0);
    return 0;
}

利用STL库中的next_permutation函数来求全排列问题:

cpp 复制代码
#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    string s;
    cin >> s;
    do cout << s << '\n';
    while(next_permutation(s.begin(), s.end()));

    return 0;
}

二、八皇后IO链接

本题思路: 利用dfs的方式找出92组解,判定该点是否可以放皇后时,用了三个bool类型的数组col[N], dg[N], udg[N]来储存某列,某正对角线,某副对角线是否可以放置,所以当其中值为true时,就不能在该点放。我们需要一个数组ans来储存答案,同时,我们得想办法把每个皇后所在列转成int类型存起来。为了方便,我们在进行dfs时可以先把答案用char类型储存在path[8]数组里面,最后转成int类型放进ans数组最后处理m次询问就行。

cpp 复制代码
#include <bits/stdc++.h>

constexpr int N=20,M=100;

int n,ans[M];//ans保存92种八皇后信息
int idx;
char path[8];
bool col[N],dg[N],udg[N];//col表示列,dg表示主对角线,udg表示副对角线

void dfs(int u)
{
    if(u==8)
    {
        ans[++idx]=atoi(path);//加入到某一种情况中
        return;
    }
    
    for(int i=0;i<8;i++){
        if(!col[i]&&!dg[u+i]&&!udg[8-u+i]){
            col[i]=dg[u+i]=udg[8-u+i]=true;
            path[u]=i+1+'0';
            dfs(u+1);
            col[i]=dg[u+i]=udg[8-u+i]=false;
        }
    }
}

int main()
{
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);std::cout.tie(nullptr);
    
    dfs(0);
    std::cin>>n;
    
    while(n--){
        int x;
        std::cin>>x;
        std::cout<<ans[x]<<std::endl;
    }
    
    return 0;
}
相关推荐
码界奇点28 分钟前
基于前后端分离架构的智能面试刷题系统设计与实现
spring boot·面试·职场和发展·架构·毕业设计·源代码管理
橘颂TA32 分钟前
【剑斩OFFER】算法的暴力美学——力扣 127 题:单词接龙
算法·leetcode·职场和发展
Swift社区1 小时前
LeetCode 380 O(1) 时间插入、删除和获取随机元素
算法·leetcode·职场和发展
GSDjisidi1 小时前
正社員・個人事業主歓迎|GSD東京本社で働こう|業界トップクラスの福利厚生完備
开发语言·面试·职场和发展
java修仙传2 小时前
力扣hot100:划分字母区间
算法·leetcode·职场和发展
努力学算法的蒟蒻2 小时前
day62(1.21)——leetcode面试经典150
面试·职场和发展
YuTaoShao3 小时前
【LeetCode 每日一题】1292. 元素和小于等于阈值的正方形的最大边长
算法·leetcode·职场和发展
重生之后端学习3 小时前
25. K 个一组翻转链表
java·数据结构·算法·leetcode·职场和发展
零售ERP菜鸟4 小时前
IT年度商业计划书框架(精简版)
大数据·人工智能·职场和发展·创业创新·学习方法·业界资讯
_OP_CHEN4 小时前
【算法基础篇】(四十九)数论之中国剩余定理终极指南:从孙子算经到算法竞赛
算法·蓝桥杯·数论·中国剩余定理·算法竞赛·乘法逆元·acm/icpc