深搜专题2:组合问题

描述

组合问题就是从n个元素中抽出r个元素(不分顺序且r < = n),

我们可以简单地将n个元素理解为自然数1,2,...,n,从中任取r个数。

例如n = 5 ,r = 3 ,所有组合为:

1 2 3

1 2 4

1 2 5

1 3 4

1 3 5

1 4 5

2 3 4

2 3 5

2 4 5

3 4 5

输入描述

一行两个自然数n、r ( 1 < n < 21,1 < = r < = n )。

输出描述

所有的组合,每一个组合占一行且其中的元素按由小到大的顺序排列,所有的组合也按字典顺序。

字典顺序及从小到大。

学会去重即可。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n,r;
int s[10];
int vis[10];
void dfs(int x,int len){//加入起点传参
    if(len==r+1){//现在不是全排列
        for(int i=1;i<=r;i++){
            cout<<s[i]<<" ";
        }
        cout<<endl;
        return;
    }
    for(int i=x;i<=n;i++){
        if(!vis[i]){
            s[len]=i;
            vis[i]=1;
            dfs(i,len+1);//传入新起点
            vis[i]=0;
        }
    }
}
int main(){
    cin>>n>>r;
    dfs(1,1);
    return 0;
}
相关推荐
wbs_scy3 分钟前
C++:二叉搜索树(BST)完全指南(从概念原理、核心操作到底层实现)
数据结构·算法
东华万里4 分钟前
Release 版本禁用 assert:NDEBUG 的底层逻辑与效率优化
java·jvm·算法
liulilittle11 分钟前
C++ CRTP 替代虚函数
数据结构·c++·算法
电摇小人16 分钟前
莫比乌斯反演详细解说来啦!!!
数据结构·算法
7澄122 分钟前
数据结构进阶:从链表到红黑树(二叉树、平衡树、红黑树核心解析)
数据结构·链表·二叉树·红黑树·平衡二叉树·旋转·二叉排序树
buyue__28 分钟前
C++实现数据结构——队列
数据结构·c++
Hui Baby30 分钟前
LSM 原理、实现及与 B+ 树的核心区别
java·linux·算法
爬山算法1 小时前
Netty(13)Netty中的事件和回调机制
java·前端·算法
hweiyu001 小时前
数据结构:广义表
数据结构
CoovallyAIHub1 小时前
是什么支撑L3自动驾驶落地?读懂AI驾驶与碰撞预测
深度学习·算法·计算机视觉