博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C语言 · 排列数
阅读量:5060 次
发布时间:2019-06-12

本文共 1113 字,大约阅读时间需要 3 分钟。

算法提高 排列数  
时间限制:1.0s   内存限制:256.0MB
    
问题描述
  0、1、2三个数字的全排列有六种,按照字母序排列如下:
  012、021、102、120、201、210
  输入一个数n
  求0~9十个数的全排列中的第n个(第1个为0123456789)。
输入格式
  一行,包含一个整数n
输出格式
  一行,包含一组10个数字的全排列
样例输入
1
样例输出
0123456789
数据规模和约定
  0 < n <= 10!
 
1 #include
2 #include
3 long long n,sum; 4 int label[10];//用来标记数字i是否被用了,即是否已被放在了排列中 5 int a[10]; 6 void SouSuo(int pos){ 7 if(pos==10){ //表示当前数组a中已有10个数字 8 sum++; 9 if(sum==n){ 10 for(int i=0; i<10; i++)11 printf("%d",a[i]); 12 }13 }14 for(int i=0; i<=9; i++){
//枚举数字0到数字915 if(!label[i]){
//若数字i还没被放在当前排列中16 a[pos]=i;//将i赋给当前排列a数组的第pos位置 17 label[i]=1;//数字i已放入排列中,标记为1 18 SouSuo(pos+1);//继续搜索下一个位置 19 label[i]=0;//清除标记 20 } 21 } 22 } 23 int main(){ 24 scanf("%d",&n);25 if(n==0){26 return 0;27 }28 memset(label,0,sizeof(label));//给标记赋初值0 29 sum=0; 30 SouSuo(0); 31 return 0; 32 }

 

转载于:https://www.cnblogs.com/panweiwei/p/6430527.html

你可能感兴趣的文章
「破解」Xposed强
查看>>
Linux 平台下 MySQL 5.5 安装 说明 与 示例
查看>>
src与href的区别
查看>>
ABAP工作区,内表,标题行的定义和区别
查看>>
《xxx重大需求征集系统的》可用性和可修改性战术分析
查看>>
Python 中 创建类方法为什么要加self
查看>>
关于indexOf的使用
查看>>
【转】JS生成 UUID的四种方法
查看>>
英语单词
查看>>
centos6.8下安装matlab2009(图片转帖)
查看>>
Mongo自动备份
查看>>
求助大神!怎样批量删除数据库表中某个字段中同样的一段字符!
查看>>
VMWARE虚拟机无法访问的三种方法分析
查看>>
enq: SQ - contention
查看>>
cer证书签名验证
查看>>
ant 安装
查看>>
新手Python第一天(接触)
查看>>
vue路由动态加载
查看>>
【原】UIWebView加载本地pdf、doc等文件
查看>>
iOS中ARC内部原理
查看>>