[题目链接]

https://www.lydsy.com/JudgeOnline/problem.php?id=2425

[算法]

类似与数位动态规划的思想 , 用组合数学进行简单推导即可

时间复杂度 : O(L ^ 3)

[代码]

#include<bits/stdc++.h>
using namespace std;
#define N 110
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull; #define int ll int L , L0;
int tmp[N] , digit[N] , cnt[N];
char s[N]; template <typename T> inline void chkmin(T &x , T y) { x = min(x , y); }
template <typename T> inline void chkmax(T &x , T y) { x = max(x , y); }
template <typename T> inline void read(T &x)
{
T f = ; x = ;
char c = getchar();
for (; !isdigit(c); c = getchar()) if (c == '-') f = -f;
for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
x *= f;
}
inline ll quickpow(ll a , int n)
{
ll b = a , res = ;
while (n > )
{
if (n & ) res *= b;
b = b * b;
n >>= ;
}
return res;
}
inline void add(int x , int val)
{
for (int i = ; i <= (int)sqrt(x); i++)
{
if (x % i == )
{
while (x % i == )
{
tmp[i] += val;
x /= i;
}
}
}
if (x > ) tmp[x] += val;
} signed main()
{ scanf("%s" , s + );
L = strlen(s + );
for (int i = ; i <= L; i++)
{
if (s[i] > '') ++L0;
++cnt[s[i] - ''];
digit[i] = s[i] - '';
}
ll ans = ;
for (int k = ; k < L;k++)
{
if (k < L0) continue;
memset(tmp , , sizeof(tmp));
for (int i = ; i <= L0; i++) add(i , );
for (int i = ; i <= ; i++)
{
for (int j = ; j <= cnt[i]; j++)
{
add(j , -);
}
}
for (int i = ; i <= k - ; i++) add(i , );
for (int i = ; i <= L0 - ; i++) add(i , -);
for (int i = ; i <= k - L0; i++) add(i , -);
ll cont = ;
for (int i = ; i <= ; i++) cont *= quickpow(i , tmp[i]);
ans += cont;
}
for (int i = ; i <= L; i++)
{
for (int j = ; j < digit[i]; j++)
{
if (i == && !j) continue;
if (!j || cnt[j] > )
{
--cnt[j];
int nowcnt = ;
for (int k = ; k <= ; k++) nowcnt += cnt[k];
if (nowcnt > L - i)
{
++cnt[j];
continue;
}
memset(tmp , , sizeof(tmp));
for (int k = ; k <= nowcnt; k++) add(k , );
for (int x = ; x <= ; x++)
{
for (int y = ; y <= cnt[x]; y++)
{
add(y , -);
}
}
for (int k = ; k <= L - i; k++) add(k , );
for (int k = ; k <= nowcnt; k++) add(k , -);
for (int k = ; k <= L - i - nowcnt; k++) add(k , -);
ll cont = ;
for (int k = ; k <= ; k++) cont *= quickpow(k , tmp[k]);
ans += cont;
++cnt[j];
}
}
--cnt[digit[i]];
}
printf("%lld\n" , ans); return ;
}

[HAOI 2010] 计数的更多相关文章

  1. [HAOI 2010]软件安装

    Description 现在我们的手头有N个软件,对于一个软件i,它要占用Wi的磁盘空间,它的价值为Vi.我们希望从中选择一些软件安装到一台磁盘容量为M计算机上,使得这些软件的价值尽可能大(即Vi的和 ...

  2. [HAOI 2010]订货

    Description 题库链接 某公司估计市场在第 \(i\) 个月对某产品的需求量为 \(U_i\) ,已知在第 \(i\) 月该产品的订货单价为 \(d_i\) ,上个月月底未销完的单位产品要付 ...

  3. [ HAOI 2010 ] 最长公共子序列

    \(\\\) \(Description\) 求两个长度\(\le5000\)的大写字母串的\(LCS\)长度及个数,定义两\(LCS\)中某一字符在两序列出现位置有一处不同就视为不同. \(\\\) ...

  4. BZOJ 2427 /HAOI 2010 软件安装 tarjan缩点+树形DP

    终于是道中文题了.... 当时考试的时候就考的这道题.... 果断GG. 思路: 因为有可能存在依赖环,所以呢 先要tarjan一遍 来缩点. 随后就进行一遍树形DP就好了.. x表示当前的节点.j表 ...

  5. BZOJ 2467: [中山市选2010]生成树 [组合计数]

    2467: [中山市选2010]生成树 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 638  Solved: 453[Submit][Status][ ...

  6. [ZJOI 2010]Perm 排列计数

    Description 题库链接 询问有多少个 \(1\sim N\) 的排列 \(P\) 满足" \(\forall i\in[2,N], P_i>P_{\frac{i}{2}}\) ...

  7. [ZJOI 2010]count 数字计数

    Description 题库链接 问你 \([l,r]\) 区间内所有整数中各个数码出现了多少次. \(1\leq a\leq b\leq 10^{12}\) Solution 数位 \(DP\) . ...

  8. 「ZJOI 2010」 排列计数

    题目链接 戳我 \(Solution\) 其实我们可以发现这题等价于让你求: 用\(1\)~\(n\)的数组成一个完全二叉树使之满足小根堆性质的方案数 于是我们可以考虑\(dp\) 假设我们现在在\( ...

  9. [ZJOI 2010] 排列计数

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2111 [算法] 一种比较好的理解方式是将该序列看成是一棵堆式存储的二叉树 那么问题转 ...

随机推荐

  1. Utuntu 和 window共享文件

    由于自己想用服务器跑代码,数据集和模型一般都在本机电脑上,用实验室服务器需要拷贝数据或者,在服务器上重新下载数据很麻烦 都在局域网内可以实现文件共享,代码和数据都在本地,共享给服务器,只需要使用服务器 ...

  2. C#中toolStrip或statusStrip遮挡了SplitContainer怎么办?

    如果在一个项目中先增添了SplitContainer,然后再添加的Toolbar或statusStrip,结果后者把前者上部或下部挡住了一条,造成界面别扭. 解决办法是右键点击Toolba或statu ...

  3. Android MPAndroidCharts 框架 画可滑动查看的直方图

    1.由于公司项目的需求,所以花了1.2天研究 MPAndroidCharts框架 .可是发现好多博客对我都没得帮助.浪费非常多时间在百度上.不得不说google 真是比百度强太多了. 要求:统计出56 ...

  4. ffmpeg 视频教程 添加水印附源码

    本文主要讲述如何利用Ffmpeg向视频文件 添加水印这一功能,文中最后会给出源代码下载地址以及视频 下载地址,视频除了讲述添加水印的基本原理以及代码实现,还提到了要注意的一些地方,因为直接运行 dem ...

  5. Flash制作和软件使用

    Flash制作和软件使用 2014-11-09 ——君子善假于物也 引子 虽说FLASH在随着HTML5的发展而受阻,尤其移动终端都不再支持它了,但是在一段时间内还是重要的.近期朋友说要结婚,想弄个电 ...

  6. POJ 3469(Dual Core CPU-最小割)[Template:网络流dinic V2]

    Language: Default Dual Core CPU Time Limit: 15000MS   Memory Limit: 131072K Total Submissions: 19321 ...

  7. 关于erlang解析json数据

    JSON(JavaScript Object Notation)是一种轻量级的数据交换语言,以文字为基础,且易于让人阅读.json的数据格式是文本文档格式的一种.在erlang中可以参考mochiwe ...

  8. Webkit二:RenderTree 创建

    RenderObject 作为所有Render 树节点的基类,完全类似与DOM树中的Node基类,它是构成Render 树的基础,作用非比寻常,其中包含了构成Render 树所可能涉及到的一些基本属性 ...

  9. asp.net mvc4 修改密码界面

    1.效果 说明:1.界面不太美观 这里面主要是包括 利用jQuery 插件validate验证form字段,jQuery提交form表单的方式 1.HTML代码 <!DOCTYPE html&g ...

  10. MFC获取电脑硬盘序列号(附源代码)

    在新建的project里面加入一个类  即:下面一个类  GetHDSerial.cpp <code class="hljs cs has-numbering" style= ...