Codeforces-121C(逆康托展开)
题目大意:
给你两个数n,k求n的全排列的第k小,有多少满足如下条件的数:
首先定义一个幸运数字:只由4和7构成
对于排列p[i]满足i和p[i]都是幸运数字
思路:
对于n,k<=1e9
一眼逆康托展开
什么?你不知到康托展开?
由于阶乘的增长是非常快的
13的阶乘就大于1e9了
所以说:
对于一个n的权排列 1 2 3 4 ...... n
我们最多动他的后13位就可以得到第k小的排列
我们称之为动n的后x位可以得到第k小的排列(如果这里都取13的话,有的序列是n<13的,会越界)
然后我们对[1,n-x]中的数字统计答案的时候可以数位dp,可以dfs
然后对后x位统计答案,就是裸的逆康托展开了
Code:

ll n, k, x, fac[20], ans;
std::vector<ll> v;
ll suf[20], cnt;
void dfs(ll num, ll top)
{
// cout<<top<<endl;
if(num > top) return ;
if(num <= top && num != 0)ans++;
dfs(num * 10 + 4, top);
dfs(num * 10 + 7, top);
}
int ok(ll x)
{
int flag = 1;
while(x)
{
int yy = x % 10;
// cout<<yy<<"@"<<endl;
if(yy != 4 && yy != 7) flag = 0;
x /= 10;
}
return flag;
}
void re_count()
{
sort(v.begin(), v.end());
for(int i = x ; i >= 1 ; i--)
{
ll pos = k / fac[i - 1];
k = k % fac[i - 1];
suf[++cnt] = v[pos];
v.erase(v.begin() + pos);
} }
int main()
{
fac[0] = 1;
rep(i, 1, 16) fac[i] = i * fac[i - 1];
n = read(), k = read();
k--;
for(int i = 1 ; i <= 16; i++)
{
if(fac[i] >k)
{
x = i;
break;
}
}
// cout<<x<<"#"<<endl;
for(int i = n; i >= n - x + 1; i--) v.push_back(i);
if(n - x < 0)
{
cout << -1;
return 0;
}
dfs(0, n - x); //搜出n-x的幸运数
re_count();
for(int i = n - x + 1; i <= n; i++) if(ok(i) && ok(suf[i - (n - x)])) ans++;
out(ans);
return 0;
}
Codeforces-121C(逆康托展开)的更多相关文章
- LightOJ1060 nth Permutation(不重复全排列+逆康托展开)
一年多前遇到差不多的题目http://acm.fafu.edu.cn/problem.php?id=1427. 一开始我还用搜索..后来那时意外找到一个不重复全排列的计算公式:M!/(N1!*N2!* ...
- nyoj 139——我排第几个|| nyoj 143——第几是谁? 康托展开与逆康托展开
讲解康托展开与逆康托展开.http://wenku.baidu.com/view/55ebccee4afe04a1b071deaf.html #include<bits/stdc++.h> ...
- 题解报告:NYOJ 题目143 第几是谁?(逆康托展开)
描述 现在有"abcdefghijkl”12个字符,将其按字典序排列,如果给出任意一种排列,我们能说出这个排列在所有的排列中是第几小的.但是现在我们给出它是第几小,需要你求出它所代表的序列. ...
- HDU1027 Ignatius and the Princess II( 逆康托展开 )
链接:传送门 题意:给出一个 n ,求 1 - n 全排列的第 m 个排列情况 思路:经典逆康托展开,需要注意的时要在原来逆康托展开的模板上改动一些地方. 分析:已知 1 <= M <= ...
- 康托展开&逆康托展开学习笔记
啊...好久没写了...可能是最后一篇学习笔记了吧 题目大意:给定序列求其在全排列中的排名&&给定排名求排列. 这就是康托展开&&逆康托展开要干的事了.下面依次介绍 一 ...
- hdoj 1027 Ignatius and the Princess II 【逆康托展开】
Ignatius and the Princess II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K ( ...
- 康托展开与逆康托展开模板(O(n^2)/O(nlogn))
O(n2)方法: namespace Cantor { ; int fac[N]; void init() { fac[]=; ; i<N; ++i)fac[i]=fac[i-]*i; } in ...
- DeCantor Expansion (逆康托展开)
Background\text{Background}Background The \text{The }The Listen&Say Test will be hold on May 11, ...
- cf121C. Lucky Permutation(康托展开)
题意 题目链接 Sol 由于阶乘的数量增长非常迅速,而\(k\)又非常小,那么显然最后的序列只有最后几位会发生改变. 前面的位置都是\(i = a[i]\).那么前面的可以直接数位dp/爆搜,后面的部 ...
随机推荐
- Flutter WillPopScope 拦截路由返回
WillPopScope addScopedWillPopCallback 启用此路由以使用户否决尝试以将其关闭. 典型应用是如果用户尝试退出表单,则警告用户有关未保存的表单数据.连按两次返回键退出A ...
- element-ui的树型结构图,半选状态数据给后台后,返回数据带有半选父节点的剔除展示
// html <h2 class="text-gray">功能权限</h2><el-tree :data="permissionList& ...
- DOM事件对象用法
分为三个阶段:事件捕获阶段.目标阶段.事件冒泡阶段. 事件捕获老版本浏览器(IE<=8)不支持,但是事件冒泡可以放心使用. 事件处理程序 一共四类写法,基本都见过,看下写法就知道怎么回事儿了. ...
- Baccarat流动性挖矿是如何改进自动化做市商的痛点的?
Baccarat自上线至今已经有两个多月的时间,尤其代币BGV引来了无数投资者的注意.同时也有越来越多的投资者开始关注到Baccarat本身,Baccarat采取的AMM机制,与其他的DeFi项目所采 ...
- BGV暴涨千倍,未来或将超越YFI领跑DeFi全场!
毫无疑问,YFI在2020年上半年以一己之力掀翻了DeFi市场的热潮.迄今为止,YFI的新鲜资讯从不缺席,最近也是频频登上各大知名媒体热搜.其币价远远超过比特币价格,也让资本市场注意到DeFi市场原来 ...
- elasticsearch如何设计索引
本文为博客园作者所写: 一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 最近在做es相关的工作,所以记录下自己的一些想法,可能很多方面不会很全面,但是基本都是经过 ...
- CF102920L Two Buildings【分治】【决策单调性】
优秀的分治题目.是"2020-2021 ACM-ICPC, Asia Seoul Regional Contest"的一道题. Description There are \(n\ ...
- django学习-4.url动态传值
1.前言 我们在浏览器访问一个网页A是通过一个指定的url地址去访问的.但在浏览器用一个不存在的url地址去执行访问是打不开正确的网页的,只会打开一个浏览器自带的有错误提示的网页. 在django框架 ...
- linux查看目录文件以及子目录文件大小的命令
可以使用以下命令,不过如果文件比较多,因为是递归统计大小的的,所以结果出来的会比较慢,需要等待. du -h --max-depth=1 * 以下是命令的说明 du [-abcDhHklmsSx] [ ...
- mybites框架遇到的坑之Mapper.xml文件不要随意加注释和ORA-00911
原文链接:https://blog.csdn.net/streetlight8023/article/details/69388495/ 先说解决方法: org.mybatis.spring.MyBa ...