LightOJ1298 One Theorem, One Year (欧拉函数dp)
题意:给你almost-K-First-P-Prime, 如果一个数x有k个质因子,且这k个质因子包含且仅包含前p个质数满足条件。 让你求Σφ(x);
思路:首先我们这p个因子一定要有,也就是剩下k-p个因子是什么了,剩下的因子每个都可以取前p个质数中的任意一个。想到这就有一种背包的感觉,然后在不知道状态转移方程的情况下,我们知道状态转移方程中的选还是不选怎么更新,就要用到欧拉函数更新了:
- φ(p)=p-1(p是质数)
- φ(p*a)=(p-1)*φ(a)(p是质数且p不能整除a)
- φ(p*a)=p*φ(a)(p是质数且p|a)
然后我就想到这。。。。开始搜索题解,对我来说太玄学了,看别人也没什么过渡,我是想不到。
dp[i][j]直接存的是答案,当一个质数没出现过,用到性质2,dp[i][j] = dp[i-1][j-1] * (prime[j] - 1) , 一个质数出现过可以用性质3,dp[i][j] += dp[i-1][j] * prime[j]。
#include <bits/stdc++.h>
#define ll long long
#define INF 0x3f3f3f3f3f3f3f3f
#define met(a, b) memset(a, b, sizeof(a))
using namespace std;
const int N = 4000;
const ll mod = 1000000007;
bool vis[N];
ll prime[N], dp[505][505];
void get_prime(){
int pos = 0; vis[1] = 1;
for(ll i = 2; i <= 3600; i++){
if(!vis[i]) prime[++pos] = i;
for(ll j = 1; j <= pos && prime[j]*i <= 3600; j++){
vis[i*prime[j]] = 1;
if(i%prime[j] == 0) break;
}
}
} void init(){
dp[0][0] = 1;
for(int i = 1; i <= 500; i++){
for(int j = 1; j <= i; j++){
dp[i][j] += dp[i-1][j-1] * (prime[j] - 1) % mod; //这个质数第一次被选
if(i-1 >= j) dp[i][j] = (dp[i][j]+dp[i-1][j]*prime[j])%mod; //这个质数之前选过
}
}
} int main(){
get_prime();
init();
int T, cas = 0; cin >> T;
while(T--){
int k, p;
cin >> k >> p;
printf("Case %d: %lld\n", ++cas, dp[k][p]);
}
return 0;
}
LightOJ1298 One Theorem, One Year (欧拉函数dp)的更多相关文章
- LightOJ1298 One Theorem, One Year(DP + 欧拉函数性质)
题目 Source http://www.lightoj.com/volume_showproblem.php?problem=1298 Description A number is Almost- ...
- hdu2588 GCD (欧拉函数)
GCD 题意:输入N,M(2<=N<=1000000000, 1<=M<=N), 设1<=X<=N,求使gcd(X,N)>=M的X的个数. (文末有题) 知 ...
- BZOJ 2705: [SDOI2012]Longge的问题 [欧拉函数]
2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 2553 Solved: 1565[Submit][ ...
- BZOJ 2818: Gcd [欧拉函数 质数 线性筛]【学习笔记】
2818: Gcd Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 4436 Solved: 1957[Submit][Status][Discuss ...
- COGS2531. [HZOI 2016]函数的美 打表+欧拉函数
题目:http://cogs.pw/cogs/problem/problem.php?pid=2533 这道题考察打表观察规律. 发现对f的定义实际是递归式的 f(n,k) = f(0,f(n-1,k ...
- poj2478 Farey Sequence (欧拉函数)
Farey Sequence 题意:给定一个数n,求在[1,n]这个范围内两两互质的数的个数.(转化为给定一个数n,比n小且与n互质的数的个数) 知识点: 欧拉函数: 普通求法: int Euler( ...
- 51Nod-1136 欧拉函数
51Nod: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1136 1136 欧拉函数 基准时间限制:1 秒 空间限制: ...
- 欧拉函数 - HDU1286
欧拉函数的作用: 有[1,2.....n]这样一个集合,f(n)=这个集合中与n互质的元素的个数.欧拉函数描述了一些列与这个f(n)有关的一些性质,如下: 1.令p为一个素数,n = p ^ k,则 ...
- FZU 1759 欧拉函数 降幂公式
Description Given A,B,C, You should quickly calculate the result of A^B mod C. (1<=A,C<=1000 ...
- hdu 3307 Description has only two Sentences (欧拉函数+快速幂)
Description has only two SentencesTime Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K ...
随机推荐
- tomcat各个版本下载
官网地址:https://archive.apache.org/dist/tomcat/
- fail-fast简介
转载请注明出处:http://www.cnblogs.com/skywang12345/p/3308762.html fail-fast简介(使用concurrentHashMap可以完美避免这个问题 ...
- react native 上传图片(后面有空写一个,完整的案例)
图片上传的思路很正确 https://www.jianshu.com/p/c9f030fa6754 1. 获取图片路径 利用react-native-image-crop-pick 从手机中获得图片的 ...
- iOS开发--APP性能检测方案汇总
1 . CPU 占用率 CPU作为手机的中央处理器,可以说是手机最关键的组成部分,所有应用程序都需要它来调度运行,资源有限.所以当我们的APP因设计不当,使 CPU 持续以高负载运行,将会出现APP卡 ...
- SQL-运算
dual表可以进行运算select * from dual; 算数运算 + - * /select 5 + 6 as aaa ,6 - 3 as bbb ,5 * 7 as ccc ,9/2 as d ...
- Luogu P3368 【模板】树状数组 2 [区间修改-单点查询]
P3368 [模板]树状数组 2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数数加上x 2.求出某一个数的和 输入输出格式 输入格式: 第一行包含两个整数N.M,分别表 ...
- bzoj 3924
动态点分治好题 首先我们考虑一个暴力做法: 每次修改之后选一个点作为根搜索整棵树,然后换根dp即可 考虑每次换根时,移向的点的消耗会减少子树代价之和*边权,而其余部分代价会增加剩余代价*边权 这样每次 ...
- Flink笔记
高可用(HA):直白来说就是系统不会因为某台机器,或某个实例挂了,就不能提供服务了.高可用需要做到分布式.负载均衡.自动侦查.自动切换.自动恢复等. 高吞吐: 单位时间内,能传输的数据量,对应指标就是 ...
- JetPack Compose 入门还得是官方
官方写的真不错! 和那些所谓"教程"比真的简单高效不罗嗦! 所以还得是官方! 使用 Jetpack Compose 更快地打造更出色的应用 https://developer.an ...
- 创建一个Openpyxl
from openpyxl import Workbook wb = Workbook(r'C:\Users\yjiang3\Desktop\23.xlsx') ws = wb.active from ...