题解报告:hdu 2062 Subset sequence
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2062
当n=1时,f(1)=1,a(1)=1,有1个子集合:{1};
当n=2时,f(2)=4=2*(f(1)+1),a(2)=2=f(2)/2=f(1)+1,有4个子集合:{1},{1, 2};{2},{2, 1}。
当n=3时,f(3)=15=3*(f(2)+1),a(3)=5=f(3)/3=f(2)+1,有15个子集合: {1}, {1, 2}, {1, 3},{1, 2, 3}, {1, 3, 2};
{2}, {2, 1}, {2, 3}, {2, 1, 3}, {2, 3, 1};{3}, {3, 1}, {3, 2}, {3, 1, 2}, {3, 2, 1}。
由以上规律得知:f(n)=n*(f(n-1)+1),a(n)=f(n)/n=f(n-1)+1,而a(n-1)=f(n-1)/(n-1),所以f(n-1)=(n-1)*a(n-1),
即有a(n)=a(n-1)*(n-1)+1;这就推导出每组(首元素相同的一组)的子集合个数。
下面举个栗子:n=3,m=10,m表示求n的第m个子集合,首先我们已经按照推导公式将a数组(求每组的子集合个数)打表,接下来求m是在第几个大组,t=m/a[n]+(m%a[n]>0?1:0)=10/5+0=2,表示此时该集合在第二大组,此时直接输出首元素2,剩余1,3这两个元素,该集合{2,3,1}的位置为m-(t-1)*a[n]=10-(2-1)*5=5,表示在第二大组的第5个集合这个位置,删除集合中有'2'这个元素后,剩余集合按字典序排得到{1},{1,3};{3},{3,1}。此时有两个大组,我们知道,剩下的要求的元素所在集合为第4个位置,n为原来的3个大组减去首元素都为2的这一组后变为2个大组即n=2,执行t那条语句得t=4/2+0=2,则所求当前集合在第2大组的第m-(t-1)*a[n]=4-(2-1)*2=2个位置,即所求集合在所有集合中的位置为m=10-(5+1)=4(还要减去一个空集才得到剩下集合的位置),所以此时输出首元素3,剩下1这个元素,删掉集合中有'3'这个元素后,剩下集合为{1},易知当前位置为1,即所求集合在所有集合中的位置m=4-(2+1)=1,n=1,执行t语句后t=1/1+0=1,验证m-(t-1)*a[n]=1-0=1,对应得到接着去掉'3'元素后剩下子集合中的第1大组第1个位置,所以此时输出首元素1,删掉集合中有1这个元素后变成空集,即m=1-(0+1)=0,n=0退出循环查找,即得到n=3时的第10个子集合。
结合以上规律,可以得到循环中m=m-(a[n]*(t-1)+1)直到m==0退出,并且每输出一个元素,相应的n大组数减1,直到n==0退出。
这里用s数组按下标给其字典序赋值,当输出每个元素后,后面的元素要往前移一位进行覆盖,因为不用这个元素了,且下次求该组位置的元素刚好对应首元素,这里自己可以模拟一下。
AC代码:
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n,s[],t;//n表示一共有多少个元素,s是后面将子集按照字典序分组后每组的初始首元素,组数<=20,t是所求子集位于分组后的第几位
long long m,a[]={};//m是位于第几个子集,后面是将子集分组后平均每组的个数,如a[2]表示n=2时的分组每组中子集数
for(int i=;i<;i++)
a[i]=a[i-]*(i-)+;//推导出来的,表示An中每一组的子集合个数
while(cin>>n>>m){
for(int i=;i<;i++)
s[i]=i;//每循环一次就重新归位每组首元素
while(n> && m>){
t=m/a[n]+(m%a[n]>?:);//先记录在第几个大组
if(t>){//得到第m个子集在分组后的第t组,若t>0
cout<<s[t];//先输出该组的首元素
for(int i=t;i<=n;i++)
s[i]=s[i+];//或s[i]+=1,我们发现:第n组中,第2个元素在第n个时变为它的下一个数
m-=((t-)*a[n]+);//m-(t-1组总子集数+1),m表示在剩余子集中位于第几个
putchar(m==?'\n':' ');//m最后为0,直接输出换行,不然就输出空格
}
n--;//减掉删除该首元素的一整组
}
}
return ;
}
题解报告:hdu 2062 Subset sequence的更多相关文章
- HDU 2062 Subset sequence 数位dp,思路 难度:1
http://acm.hdu.edu.cn/showproblem.php?pid=2062 Subset sequence Time Limit: 1000/1000 MS (Java/Others ...
- HDU 2062 Subset sequence (找规律)
题目链接 Problem Description Consider the aggregate An= { 1, 2, -, n }. For example, A1={1}, A3={1,2,3}. ...
- HDU 2062 Subset sequence
我是把它当做一道数学题来做的. 这篇题解写的有点啰嗦,但是是我最原始的思维过程. 对于一个集合An= { 1, 2, …, n },在n比较小的情况下,在纸上按字典顺序把所有子集排列一下. 以n=3, ...
- hdu(2062)-Subset sequence 组合数学
意甲冠军:查找集合{1,2,3...n}第一m一个排列子. 收集的线索所行的大小. 例两个元素的排列子集合按字典树排列是:{1},{1,2},{2},{2,1}: 解法:一个一个元素来确定,每次把剩余 ...
- 【HDOJ】2062 Subset sequence
这道题目非常好,饶了点儿圈子.我的思路是,先按照组排列.例如,1 2 31 2 2 1 3 11 2 3 2 1 3 ...
- HDU 2062:Subset sequence(思维)
Subset sequence Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ...
- 题解报告:hdu 1398 Square Coins(母函数或dp)
Problem Description People in Silverland use square coins. Not only they have square shapes but also ...
- 题解报告:hdu 2069 Coin Change(暴力orDP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2069 Problem Description Suppose there are 5 types of ...
- 题解报告:hdu 1028 Ignatius and the Princess III(母函数or计数DP)
Problem Description "Well, it seems the first problem is too easy. I will let you know how fool ...
随机推荐
- 常见Python运行时错误
1)忘记在 if , elif , else , for , while , class ,def 声明末尾添加 :(导致 “SyntaxError :invalid syntax”) 该错误将发生在 ...
- C语言 字符串操作 笔记
/* C语言字符串的操作笔记 使用代码和注释结合方式记录 */ # include <stdio.h> # include <string.h> int main(void) ...
- python3 base64模块代码分析
#! /usr/bin/env python3 """Base16, Base32, Base64 (RFC 3548), Base85 and Ascii85 data ...
- IO获取指定目录及其目录下子目录
一.需求:获取指定目录下,指定扩展名的文件(包含子目录中的) 二.需要用到的方法 1.FilenameFilter :返回抽象路径名的定义中表示此抽象路径名的目录中的文件的数组. filter.ac ...
- 2016/3/20 数组定义 数组遍历 超全局数组 数组元素设置(in_array() 、array_reverse()、count()、array_unique()、unset()、array_values、array_merge、array_push) 列表实例
一.数组定义 php数组与其他语言的数组的不同: 其他例如java语言 :同一种类型数据的集合. php:数组可以存储任何类型的数据.同一个数组中可以放int类型也可以放string类型 ①索引数组的 ...
- python iterable 和list、dictionary的区别和联系
1 为什么一些函数的参数指定要iterable object的,但是也可以传入list为参数? 因为list.dictionary都是iterable object. 在iterable object ...
- Django's CSRF mechanism
Forbidden (403) CSRF verification failed. Request aborted. You are seeing this message because this ...
- IT江湖--这个冬天注定横尸遍野(多数人技术迟迟无进阶,多半是懒的原因。勤是必须的)
今年江湖大事繁起,又至寒冬,冻的不仅是温度,更是人心. 这两天上班途中看到多个公众号和媒体发了很多 "XXX公司裁员50%" 等等诸如此类的文章,也真是撼动人心.寒冬,比以往来的更 ...
- TP5.x——开启跨域访问
前言 其实很简单,在入口文件的index.php添加几句header就可以了. 代码 public/index.php header("Access-Control-Allow-Origin ...
- 四:网络--NSURLConnection基本使用
一.NSURLConnection的常用类 (1)NSURL:请求地址 (2)NSURLRequest:封装一个请求,保存发给服务器的全部数据,包括一个NSURL对象,请求方法.请求头.请求体.... ...