题解报告: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 ...
随机推荐
- Random Forest 与 GBDT 的异同
曾经在看用RF和GBDT的时候,以为是非常相似的两个算法,都是属于集成算法,可是细致研究之后,发现他们根本全然不同. 以下总结基本的一些不同点 Random Forest: bagging (你懂得. ...
- 剑指Offer面试题43(Java版):n个骰子的点数
题目:把n个骰子仍在地上.全部骰子朝上一面的点数之和为s,输入n,打印出s的全部可能的值出现的概率. 解法一:基于递归求骰子的点数,时间效率不够高 如今我们考虑怎样统计每个点数出现的次数. 要向求出n ...
- swagger 如何在UI界面加入Authentication token值
接口 2.access_token 值: 3 输入值:bearer+空格+值
- HDFS的体系架构
通过对Hadoop分布式计算平台最核心的分布式文件系统HDFS.MapReduce处理过程,以及数据仓库工具Hive和分布式数据库Hbase的介绍.基本涵盖了Hadoop分布式平台的全部技术核心. H ...
- 深度学习笔记之使用Faster-Rcnn进行目标检测 (实践篇)
实验 我使用的代码是Python版本的Faster Rcnn,官方也有Matlab版本的,链接如下: py-faster-rcnn(python) faster-rcnn(matlab) 环境配置 按 ...
- python 2.*和3.*的变化
1.urllib2是python自带的模块,在python3.x中被改为urllib.request,如 <span style="font-size:12px;">u ...
- PL/SQL Developer导入导出Oracle数据库方法
前一篇博客介绍了Navicat工具备份Oracle的方法.这篇博客介绍一下使用PL/SQL Developer工具导入导出Oracle数据库的方法. PL/SQL Developer是Oracle数据 ...
- Java小白手记2:一些名词解释
看到<Java 征途:行者的地图> ,这是一篇有关java学习路径文章.对我等Java小白有指引作用.里面提到了一些基本的名词术语,有些我知道,有些不知道,再补上一些自己曾觉得模糊的,记录 ...
- bzoj2461: [BeiJing2011]符环
再做水题就没救了 考虑DP...我们把正反面一起弄 fi,j,k,u表示第几个位置,正面多了多少左括号,背面多了多少没办法消的右括号,背面结尾的左括号数 #include<cstdio> ...
- caioj1275&&hdu4035: 概率期望值6:迷宫
期望的大难题,%%ZZZ大佬的解释,不得不说这是一道好题(然而膜题解都没完全看懂,然后就去烦ZZZ大佬) 简单补充几句吧,tmp的理解是个难点,除以tmp的原因是,当我们化简时,子节点也有一个B*f[ ...