codeforces 258C Little Elephant and LCM 组合数学 枚举
题意:
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 组合数学 枚举的更多相关文章
- Codeforces 258C Little Elephant and LCM
Little Elephant and LCM #include<bits/stdc++.h> #define LL long long #define fi first #define ...
- CodeForces - 204C Little Elephant and Furik and Rubik
CodeForces - 204C Little Elephant and Furik and Rubik 个人感觉是很好的一道题 这道题乍一看我们无从下手,那我们就先想想怎么打暴力 暴力还不简单?枚 ...
- Codeforces D. Little Elephant and Interval(思维找规律数位dp)
题目描述: Little Elephant and Interval time limit per test 2 seconds memory limit per test 256 megabytes ...
- Codeforces 1264D - Beautiful Bracket Sequence(组合数学)
Codeforces 题面传送门 & 洛谷题面传送门 首先对于这样的题目,我们应先考虑如何计算一个括号序列 \(s\) 的权值.一件非常显然的事情是,在深度最深的.是原括号序列的子序列的括号序 ...
- CodeForces 259A Little Elephant and Chess
Little Elephant and Chess Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d &am ...
- Codeforces 204A Little Elephant and Interval
http://codeforces.com/problemset/problem/204/A 题意:给定一个[L,R]区间,求这个区间里面首位和末尾相同的数字有多少个 思路:考虑这个问题满足区间加减, ...
- Codeforces 429B Working out:dp【枚举交点】
题目链接:http://codeforces.com/problemset/problem/429/B 题意: 给你一个n*m的网格,每个格子上有一个数字a[i][j]. 一个人从左上角走到右下角,一 ...
- [Codeforces 204E] Little Elephant and Strings
[题目链接] https://codeforces.com/contest/204/problem/E [算法] 首先构建广义后缀自动机 对于自动机上的每个节点 , 维护一棵平衡树存储所有它所匹配的字 ...
- Codeforces Gym 100431B Binary Search 搜索+组合数学+高精度
原题链接:http://codeforces.com/gym/100431/attachments/download/2421/20092010-winter-petrozavodsk-camp-an ...
随机推荐
- java 读取文件的字节数组
/*文件64位编码*/ public static void main(String[] args) { byte[] fileByte = toByteArray(newFile); St ...
- CentOS如何挂载硬盘
远程SSH登录上CentOS服务器后,进行如下操作 提醒:挂载操作会清空数据,请确认挂载盘无数据或者未使用 第一步:列出所有磁盘 命令: ll /dev/disk/by-path 提示:如果无法确 ...
- unity, ugui input field
ugui Input Field,获取输入的字符串. 错误方法: string content=inputField.FindChild("Text").text; 这样得到的是输 ...
- c#, 输出二进制
int x=-17; string str= Convert.ToString(x,2);Debug.Log(str); 输出结果: 11111111111111111111111111101111 ...
- unity, 用unity profiler进行真机profile,需要退出360
用unity profiler进行真机profile,需要退出360.
- OpenJudge计算概论-矩阵归零消减序列和
矩阵归零消减序列和 总时间限制: 1000ms 内存限制: 65536kB 描述 给定一个n*n的矩阵( <= n <= ,元素的值都是非负整数).通过n-1次实施下述过程,可把这个矩阵转 ...
- OpenJudge计算概论-求特殊自然数【枚举法】【将整数转成字符串】
/*======================================================================== 求特殊自然数 总时间限制: 1000ms 内存限制 ...
- 使用SQL字符串反转函数REVERSE巧妙实现lastindexof功能
要实现一个简单的业务: 使用SQL脚本获取字符串'large/020700/61970b0101.jpg' 中的'61970b0101.jpg'部分. 先想到的是C#中的lastindexof,但是S ...
- SQL Server 日期的加减函数: DATEDIFF DATEADD
SQL Server 日期的加减函数: DATEDIFF DATEADD DATEDIFF: 返回跨两个指定日期的日期边界数和时间边界数, 语法:DATEDIFF ( datepart , st ...
- ASP.NET MVC 程序 报错“CS0012: 类型“System.Data.Objects.DataClasses.EntityObject”在未被引用的程序集中定义”的解决办法
运行MVC程序,具体报错信息如下: 解决方法: 打开Web.config在assemblies下加入<add assembly="System.Data.Entity, Version ...