题意:

input :

n

a1,a2,...,an

1 <= n <= 10^5

1 <= ai <= 10^5

求b数组的方案数,b数组满足:

1. 1 <= bi <= ai

2. lcm(bi) = max(bi)

solution:

2说明了b数组的每一个元素都是max(bi)的约数

则:

1.sort a数组,ma  = a[n]

2.预处理2个数组,vector<int> dive[MAXN],int pos[MAXN]

dive[i]保存i的约数,并且按照小到大排序

sort(dive[i].begin(),dive[i].end())

pos[i]表示a数组中 >= i 的数的最小位置

3.枚举max(bi):1~ma,则:

ans = sigma( dive(i).size()^(n - pos[i]+1) - (dive[i].size()-1)^(n-pos[i]+1) *

    sigma((j+1)^(pos[dive[i][j+1]])-pos[dive[i][j]]),0<=j<dive[i].size() ),1<=i<=ma

推这条公式其实就是枚举max为i,然后把b数组分成若干段,每一个段的可以选择的数就是dive[i]的部分约数,先把dive[i]排序后,可以知道每一个段可以选择的数的个数,就得到公式了。

  //File Name: cf258C.cpp
//Author: long
//Mail: 736726758@qq.com
//Created Time: 2016年02月23日 星期二 18时30分26秒 #include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>
#include <vector>
#include <cmath>
#include <map> #define LL long long
#define pb push_back using namespace std; const int MAXN = (int)1e5+;
const int MOD = (int)1e9+; int a[MAXN];
vector<int> dive[MAXN];
int pos[MAXN];
int ma; LL qp(LL x,LL y)
{
LL res = 1LL;
while(y){
if(y & )
res = res * x % MOD;
x = x * x % MOD;
y >>= ;
}
return res;
} void get_dive(int x)
{
for(int i=;i<=x;i++){
dive[i].clear();
int e = (int)sqrt(i + 0.0);
for(int j=;j<=e;j++){
if(i % j == ){
dive[i].pb(j);
if((i / j) != j)
dive[i].pb(i / j);
}
}
sort(dive[i].begin(),dive[i].end());
}
} int bs(int l,int r,int x)
{
int mid;
while(r - l > ){
mid = (l + r) >> ;
if(a[mid] < x)
l = mid;
else
r = mid;
}
if(a[l] >= x)
return l;
return r;
} void solve(int n)
{
sort(a+,a+n+);
ma = a[n];
get_dive(ma);
pos[] = ;
for(int i=;i<=ma;i++){
pos[i] = bs(pos[i-],n,i);
}
LL ans = 0LL;
LL tmp;
for(int i=;i<=ma;i++){
int x = n - pos[i] + ;
int y = (int)dive[i].size();
tmp = (qp(y,x) - qp(y-,x) + MOD) % MOD;
for(int j=;j<dive[i].size() - ;j++){
tmp = tmp * qp(j+,pos[dive[i][j+]] - pos[dive[i][j]]) % MOD;
}
ans = (ans + tmp) % MOD;
}
printf("%d\n",(int)ans);
return ;
} int main()
{
int n;
while(~scanf("%d",&n)){
for(int i=;i<=n;i++){
scanf("%d",&a[i]);
}
solve(n);
}
return ;
}

codeforces 258C Little Elephant and LCM 组合数学 枚举的更多相关文章

  1. Codeforces 258C Little Elephant and LCM

    Little Elephant and LCM #include<bits/stdc++.h> #define LL long long #define fi first #define ...

  2. CodeForces - 204C Little Elephant and Furik and Rubik

    CodeForces - 204C Little Elephant and Furik and Rubik 个人感觉是很好的一道题 这道题乍一看我们无从下手,那我们就先想想怎么打暴力 暴力还不简单?枚 ...

  3. Codeforces D. Little Elephant and Interval(思维找规律数位dp)

    题目描述: Little Elephant and Interval time limit per test 2 seconds memory limit per test 256 megabytes ...

  4. Codeforces 1264D - Beautiful Bracket Sequence(组合数学)

    Codeforces 题面传送门 & 洛谷题面传送门 首先对于这样的题目,我们应先考虑如何计算一个括号序列 \(s\) 的权值.一件非常显然的事情是,在深度最深的.是原括号序列的子序列的括号序 ...

  5. CodeForces 259A Little Elephant and Chess

     Little Elephant and Chess Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d &am ...

  6. Codeforces 204A Little Elephant and Interval

    http://codeforces.com/problemset/problem/204/A 题意:给定一个[L,R]区间,求这个区间里面首位和末尾相同的数字有多少个 思路:考虑这个问题满足区间加减, ...

  7. Codeforces 429B Working out:dp【枚举交点】

    题目链接:http://codeforces.com/problemset/problem/429/B 题意: 给你一个n*m的网格,每个格子上有一个数字a[i][j]. 一个人从左上角走到右下角,一 ...

  8. [Codeforces 204E] Little Elephant and Strings

    [题目链接] https://codeforces.com/contest/204/problem/E [算法] 首先构建广义后缀自动机 对于自动机上的每个节点 , 维护一棵平衡树存储所有它所匹配的字 ...

  9. Codeforces Gym 100431B Binary Search 搜索+组合数学+高精度

    原题链接:http://codeforces.com/gym/100431/attachments/download/2421/20092010-winter-petrozavodsk-camp-an ...

随机推荐

  1. Linux内核编译和运行(转-段玉磊)

    内核获取网站:https://www.kernel.org/pub/linux/kernel/ 步骤如下: 1.打开终端,更改用户权限为root.具体做法是在终端输入sudo su,然后按提示输入密码 ...

  2. scala言语基础学习三

    map的操作 访问fangwemap元素 修改map元素 遍历map sortmap和linkmap map元素类型tuple

  3. poj3259 最短路判环

    题意:有一些点.一些道路和一些虫洞,道路是双向的,连接两点,花费正的时间,而虫洞是单向的,连接两点,可以使时间倒退,求是否能够回到过去. 只要明确回到过去其实就是当出现一个负环的时候,不断沿这个环走, ...

  4. Git错误non-fast-forward

    Git错误non-fast-forward后的冲突解决 [日期:2012-04-21] 来源:Linux社区  作者:chain2012 [字体:大 中 小]   当要push代码到git时,出现提示 ...

  5. jQuery 屏蔽鼠标快速经过

    <script type="text/javascript">    $(".Banner ul li").bind('mouseover', fu ...

  6. Unity Meshes

    1. Unity 没有自带建模工具 2. 导入 Mesh 时,Unity 会自动寻找所引用的纹理,查找文件夹名为 Textures 的.先在本目录下找 -> 上溯在parent查找 ==> ...

  7. Unity3D研究院编辑器之脚本获取资源内存和硬盘大小

    内存 使用Profiler可以查看某个资源的内存占用情况,但是必须启动游戏,并且待查看的资源已经载入游戏中.我希望的是不启动游戏,也能看到它的内存好做统计. 硬盘 由于unity中的资源压缩格式记录在 ...

  8. HTML,XML中的转义字符

    HTML中的转义字符 HTML中<, >,&等有特别含义,(前两个字符用于链接签,&用于转义),不能直接使用.使用这三个字符时,应使用他们的转义序列,如下所示: & ...

  9. 导出多级表头表格到Excel

    方法一:用NPOI定义多级表头导出: 引用头: using NPOI.DDF; using NPOI.OpenXmlFormats.Wordprocessing; using NPOI.HSSF.Us ...

  10. CSS 使用小结

    1.文字过长显示省略号(....)  white-space: nowrap;overflow: hidden;text-overflow: ellipsis; 2.获取当前的ID : <asp ...