hdu 2062 Subset sequence【有点康拓展开的意思】
来源:互联网 发布:ubuntu 微信 编辑:程序博客网 时间:2024/05/01 21:03
Subset sequence
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 3441 Accepted Submission(s): 1740
Problem Description
Consider the aggregate An= { 1, 2, …, n }. For example, A1={1}, A3={1,2,3}. A subset sequence is defined as a array of a non-empty subset. Sort all the subset sequece of An in lexicography order. Your task is to find the m-th one.
Input
The input contains several test cases. Each test case consists of two numbers n and m ( 0< n<= 20, 0< m<= the total number of the subset sequence of An ).
Output
For each test case, you should output the m-th subset sequence of An in one line.
Sample Input
1 12 12 22 32 43 10
Sample Output
111 222 12 3 1
题意:给出n和m,然后有很多个集合{1,2,,,,n}的非空子集,按照一定方式排列,例如n==3时,
1
1 2
1 2 3
1 3
1 3 2
2
2 1
2 1 3
2 3
2 3 1
3
3 1
3 1 2
3 2
3 2 1
然后输出第m个序列。
结题思路,仔细观察可以看出,1、2、3开头的集合个数是一样多的,因此那m/(每组个数)可以得出第一个数字,然后依次类推即可
#include<cstdio>#include<iostream>#define LL long long intusing namespace std;int main(){ int n,a[21],i; LL m,t; LL p[21]={0,1}; for(i=2;i<=20;i++){ p[i]=p[i-1]*(i-1)+1;//0、1、2、5、16 } while(cin>>n>>m){ for(i=0;i<=20;i++) a[i]=i; while(n--&&m){ t=m/p[n+1]+((m%p[n+1])?1:0); cout<<a[t];//当前的首数字 for(i=t;i<=n;i++) a[i]=a[i+1];//回到n-1个数字,更新输出数组 m-=((t-1)*p[i]+1);//去掉前面的小于t开头的组合,且将去掉一个仅有t的集合 printf(m==0?"\n":" "); } } return 0;}
0 0
- hdu 2062 Subset sequence【有点康拓展开的意思】
- hdu 2062 Subset sequence
- HDU 2062 Subset sequence
- hdu 2062 Subset sequence
- hdu 2062 Subset sequence
- HDU 2062 Subset sequence
- HDU 2062 Subset sequence
- hdu 2062 Subset sequence
- HDU 2062 Subset sequence
- Hdu 2062 Subset sequence
- HDU 2062:Subset sequence
- HDU 2062 Subset sequence[排列组合]
- HDU 2062 Subset sequence (数学)
- hdu 2062 Subset sequence 解题报告
- hdu(2062)-Subset sequence 组合数学
- HDU 2062 Subset sequence 【好题】
- HDU 2062 Subset sequence (xjb搞)
- HDU ACM 11 2062 Subset sequence
- 程序员成长系列--应该读的通用技术书籍列表
- 网络基本功(十一):TCP窗口调整与流控
- 图表到项目的简单集成(Echarts 和 HighCharts)
- poj 1390 Blocks
- 网络基本功(十二):细说Linux网络配置(上)
- hdu 2062 Subset sequence【有点康拓展开的意思】
- hibernate 中文文档
- PB动态生成数据窗口的一个例子
- 网络基本功(十三):细说Linux网络配置(下)
- Majority Element
- 一种基于消失点的单幅未校图像测量新方法
- Unity插件-AutoTileSet介绍
- linux网络协议栈1
- <深入剖析Nginx> nginx的跟踪与调试