博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ2425:[HAOI2010]计数——题解
阅读量:6720 次
发布时间:2019-06-25

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

你有一组非零数字(不一定唯一),你可以在其中插入任意个0,这样就可以产生无限个数。比如说给定{1,2},那么可以生成数字12,21,102,120,201,210,1002,1020,等等。

现在给定一个数,问在这个数之前有多少个数。(注意这个数不会有前导0).

题意看了半天终于看懂了。

我们从高位到低位枚举比当前位小的数,然后对于剩下的元素放在后面全排列即可。

可重元素全排列=元素个数!/每个元素个数!的乘积。

防止爆ll可以将分子分母分解后约分再计算。

(貌似本质上是一道很暴力有点思维的水题,不是数位dp)

#include
#include
#include
#include
#include
#include
using namespace std;typedef long long ll;const int N=51;inline int read(){ int X=0,w=0;char ch=0; while(!isdigit(ch)){w|=ch=='-';ch=getchar();} while(isdigit(ch))X=(X<<3)+(X<<1)+(ch^48),ch=getchar(); return w?-X:X;}char s[N];int n,sum,t[11],p[N];ll ans=0;int main(){ cin>>s+1; n=strlen(s+1); for(int i=1;i<=n;i++)t[s[i]-'0']++,sum++; for(int i=1;i<=n;i++){ for(int j=0;j

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:+

+++++++++++++++++++++++++++++++++++++++++++

转载于:https://www.cnblogs.com/luyouqi233/p/8970411.html

你可能感兴趣的文章
Spring Cloud(二)Consul 服务治理实现
查看>>
mysql备份还原(视图、存储过程)
查看>>
快速配置oralce11g安装环境脚本
查看>>
int.Parse
查看>>
光纤跳线
查看>>
day02:管道符、shell及环境变量
查看>>
php设计模式——适配器模式
查看>>
C#文件、文件夹操作
查看>>
MySQL编译安装加入service
查看>>
以rsync进行同步镜像备份
查看>>
热烈祝贺VMware View4.5荣获“2010年度最佳产品”大奖
查看>>
ORACLE 11G 中表空间传输 TransportableTablespace
查看>>
自动化1
查看>>
Jenkins 2.32.3参数化构建maven项目
查看>>
使用Oracle存储过程批量生成测试数据
查看>>
正则表达式 - ×××
查看>>
Target runtime Apache Tomcat v6.0 is not defined
查看>>
.net密码找回
查看>>
安装mysql遇到的问题
查看>>
我的友情链接
查看>>