AcWing 94. 递归实现排列型枚举

文章目录

前言

差点忘记写题了,最近把手机上面的 csdn 卸载了,自己总喜欢做一些无病呻吟,没啥意思,一个男人就应该努力追求事业,要么死在罗马,要么死在路上。无病呻吟算啥呢。现在敲代码还是得看着键盘,因为总是不可避免要敲一些符号,我完全不知道符号在哪个位置,之后再刻意练习一下,希望明年的现在可以完全盲打,键盘上面的所有键位都非常熟悉。现在练习到 w 这个字母,还差七个字母,希望练完字母之后还有符号的练习,要是没有的话我就得自己另外练习一下。

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=15;
int path[N];
bool st[N];
int n;
void dfs(int u){
    if(u==n){
        for(int i=0;i<n;i++){
            cout<<path[i]<<" ";
        }
        cout<<endl;
        return;
    }
    for(int i=0;i<n;i++){
        if(!st[i]){
            path[u]=i+1;
            st[i]=true;
            dfs(u+1);
            path[u]=0;
            st[i]=false;
        }
    }
}
int main(){
    cin>>n;
    dfs(0);
    return 0;
}

思路

就是一个非常裸的深搜,早几天还写了的,现在有点写不出来了。呜呜。看了一下,就是上周四写的。真是服了。AcWing 842. 排列数字(周四),嗷嗷不是,是 11/21 ,今天是 12/5 ,上上周四,哈哈哈。我现在把代码删掉重新写一遍。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=11;
int n;
int path[N];
bool st[N];
void dfs(int u){
    if(u==n){
        for(int i=0;i<n;i++){
            cout<<path[i]<<" ";
        }
        cout<<endl;
        return;
    }
    for(int i=0;i<n;i++){
        if(!st[i]){
            path[u]=i+1;
            st[i]=true;
            dfs(u+1);
            path[u]=0;
            st[i]=false;
        }
    }
}
int main(){
    cin>>n;
    dfs(0);
    return 0;
}

现在不想写新题了,准备把以前写过的题找出来写一写,感觉以前写过的题也写不出来,写算法题的性价比是真的低。

相关推荐
程序猿炎义38 分钟前
【Easy-VectorDB】Faiss数据结构与索引类型
数据结构·算法·faiss
天赐学c语言1 小时前
1.20 - x的平方根 && vector的扩容机制以及删除元素是否会释放内存
c++·算法·leecode
52Hz1182 小时前
力扣24.两两交换链表中的节点、25.K个一组反转链表
算法·leetcode·链表
老鼠只爱大米2 小时前
LeetCode经典算法面试题 #160:相交链表(双指针法、长度差法等多种方法详细解析)
算法·leetcode·链表·双指针·相交链表·长度差法
ValhallaCoder3 小时前
Day53-图论
数据结构·python·算法·图论
老鼠只爱大米3 小时前
LeetCode经典算法面试题 #84:柱状图中最大的矩形(单调栈、分治法等四种方法详细解析)
算法·leetcode·动态规划·单调栈·分治法·柱状图最大矩形
C雨后彩虹3 小时前
羊、狼、农夫过河
java·数据结构·算法·华为·面试
重生之后端学习3 小时前
19. 删除链表的倒数第 N 个结点
java·数据结构·算法·leetcode·职场和发展
aini_lovee3 小时前
严格耦合波(RCWA)方法计算麦克斯韦方程数值解的MATLAB实现
数据结构·算法·matlab
安特尼4 小时前
推荐算法手撕集合(持续更新)
人工智能·算法·机器学习·推荐算法