题意:

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. 利用caffe生成 lmdb 格式的文件,并对网络进行FineTuning

    利用caffe生成 lmdb 格式的文件,并对网络进行FineTuning 数据的组织格式为: 首先,所需要的脚本指令路径为: /home/wangxiao/Downloads/caffe-maste ...

  2. svn tree conflicts 解决方法

    svn resolve --accept working -R XXX. 其中XXX为提示冲突的目录.

  3. 谷歌浏览器chrome与firefox的冲突(未解之谜)

    那年,公司开发了一套在线制作电子书的系统 e-textbook. 我负责小学电脑科教材在线题目的制作. 利用 ps制作剪裁好图片,导入系统,制作题目,并通知同事添加代码. 检测时,却发现有一道图片拖放 ...

  4. rac ASM下最简单归档开启方法

    原创作品,出自 "深蓝的blog" 博客,深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/47172639本次先 ...

  5. 拿什么来拯救你,我的table

    分类: Html/CSS | 转载请注明: 出自 海玉的博客 本文地址: http://www.hicss.net/how-to-save-you-my-table/ table曾经在网页开发中占据着 ...

  6. argparse

    import argparse def test(a,b): print int(a)+int(b) parser = argparse.ArgumentParser() parser.add_arg ...

  7. Java_数组

    一.java数组 1.数组定义:数组就是形象于一个容器(容器即可理解为:装东西的容器) 2.数组特征:数据是连续的,分配大小固定,数组中数据类型完全一致 创建规则:int[] arr = new in ...

  8. SQL Server 备份故障

    故障信息如下: 标题: Microsoft SQL Server Management Studio------------------------------备份 对于 服务器“*******”失败 ...

  9. Maven中Spring-Data-Redis存储对象(redisTemplate)

    Redis是一种nosql数据库,在开发中常用做缓存.Jedis是Redis在java中的redis- client.在此之前,希望已经了解redis的基本使用和Maven的使用.建立Maven Pr ...

  10. android模拟器不能用键盘

    android模拟器不能用键盘?咋整啊?