当前位置: 首页 > news >正文

深搜专题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 )。

输出描述

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

字典顺序及从小到大。

学会去重即可。

#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;
}


http://www.mrgr.cn/news/91962.html

相关文章:

  • 顺序表和STL——vector【 复习笔记】
  • Deepseek R1 和其他的大模型 共同辅助决策交通出行方案
  • java网络编程
  • Python项目源码34:网页内容提取工具1.0(Tkinter+requests+html2text)
  • QT 基础知识点
  • CLion配置源码阅读工具SourceTrail 阅读GCC
  • Linux基本指令(三)+ 权限
  • pipeline 使用git parameter插件实现动态选择分支构造
  • Windows辉煌的发展历程
  • 数据结构、算法和STL简介 【复习笔记】
  • 【Akashic Records】THE EGG
  • 正确清理C盘空间
  • bind()函数的概念和使用案例
  • windows11那些事
  • HTML项目一键打包工具:HTML2EXE 最新版
  • socket()函数的概念和使用案例
  • Spring源码分析の依赖注入(byNamebyType模式)
  • 【面试系列】Java开发--AI常见面试题
  • 设计心得——解耦的实现技术
  • Python采用DeepSeekR1本地部署+本地API接口实现简单对话