D. Soldier and Number Game
time limit per test

3 seconds

memory limit per test

256 megabytes

input

standard input

output

standard output

-> Link <-

题目链接呈上;

题意:两个人玩游戏,其中一个人选一个数n给另外一个人,然后每轮选一个数x使得n能被x整除,然后用n/=x;注意x>1;问要使得另一个人得分最高,最高多少;即最多能够玩几轮n变成了1,为了使游戏更加有趣,给出两个数a,b;n=a!/b!;其中数据范围是500,0000;

思路:我们观察样例,第一组n=3!/1!=6,然后6可以选2或3进行整除,得到的还是2或3,因为这个时候变成了素数再选只能选本身才能整除;所以只有2轮;再看第二组,n=6!/3!=120;所以n=120/2=60/2=30/2=15/3=5/5=1;总共5轮,我们的目的是什么?要使得n尽量多整除几轮,所以每次都选一个最小的素因子来整除,这样所得的分才最高;那么选最小的素因子怎么选呢?我们观察到:6=2*3,120=2*2*2*3*5;明白了吧,这个n的拆分的素因子个数就是最多能整除的轮数,那么我们就是要求出n的素因子个数了,题目数据比较大,直接求得用到高精度,我们来看n是怎么得来的呢?n=a!/b!,题目已表明b<=a,所以n=(b+1)*(b+2)*(b+3)*...*a;,我们只需求出从b+1到a中的素因子个数就是答案了,基于数据太大,所以我们要打表求出
1 - 5000000中每个数的素因子数;

然而比赛的时候想到了一种方法,却疏漏了一点致使成功离我们远去;我们观察到4=2*2,有2个,而8=2*2*2,有三个;再看6=2*3,有2个,12=6*2,有2+1个,所以当时想的方法就是用各个因子的素因子数来累加,来看这种思路代码:

const int N=5000000+10;
int a[N];
int main()
{
memset(a,0,sizeof(a));
for(int i=2; i<=N; i++)
if(!a[i])//就是没考虑到这里,所以以为会超时直接不敢写了...............
{
for(int j=i;j<=N;j+=i)
a[j]=a[j/i]+1;
}
for(int i=2;i<=N;i++)//这里要注意累加,因为查询次数比较多,每次都用循环累加也是会超时的;
a[i]+=a[i-1];
int t,n,m;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
printf("%d\n",a[n]-a[m]);
}
return 0;
}

再来看另一种思路打表代码:

const int N=5000000+10;
int a[N];
int main()
{
memset(a,0,sizeof(a));
for(int i=2; i<=N; i++)//这居然也不超时..古凯队长也是叼;;
if(!a[i])
{
long long temp;
for(temp=i;temp<=N;temp*=i)
for(long long j=temp;j<=N;j+=temp)
a[j]++;//这种更好理解一点,直接加上去;
}
for(int i=2;i<=N;i++)
a[i]+=a[i-1];
int t,n,m;
scanf("%d",&t);
while(t--)
{
// scanf("%d",&n);
// printf("%d\n",a[n]);
scanf("%d%d",&n,&m);//其实当n==m时n==1,直接输出0,特判一下省时间;;
printf("%d\n",a[n]-a[m]);
}
return 0;
}

Codeforces Round #304 (Div. 2)-D. Soldier and Number Game,素因子打表,超时哭晕~~的更多相关文章

  1. Codeforces Round #304 (Div. 2) D. Soldier and Number Game 素数打表+质因数分解

    D. Soldier and Number Game time limit per test 3 seconds memory limit per test 256 megabytes input s ...

  2. DP+埃氏筛法 Codeforces Round #304 (Div. 2) D. Soldier and Number Game

    题目传送门 /* 题意:b+1,b+2,...,a 所有数的素数个数和 DP+埃氏筛法:dp[i] 记录i的素数个数和,若i是素数,则为1:否则它可以从一个数乘以素数递推过来 最后改为i之前所有素数个 ...

  3. 数学+DP Codeforces Round #304 (Div. 2) D. Soldier and Number Game

    题目传送门 /* 题意:这题就是求b+1到a的因子个数和. 数学+DP:a[i]保存i的最小因子,dp[i] = dp[i/a[i]] +1;再来一个前缀和 */ /***************** ...

  4. Codeforces Round #304 (Div. 2) D. Soldier and Number Game 数学 质因数个数

    D. Soldier and Number Game Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/conte ...

  5. Codeforces Round #304 (Div. 2) D - Soldier and Number Game

    D. Soldier and Number Game time limit per test 3 seconds memory limit per test 256 megabytes input s ...

  6. Codeforces Round #304 (Div. 2)(CF546D) Soldier and Number Game(线性筛)

    题意 给你a,b(1<=b<=a<=5000000)表示a!/b!表示的数,你每次可以对这个数除以x(x>1且x为这个数的因子)使他变成a!/b!/x, 问你最多可以操作多少次 ...

  7. queue+模拟 Codeforces Round #304 (Div. 2) C. Soldier and Cards

    题目传送门 /* 题意:两堆牌,每次拿出上面的牌做比较,大的一方收走两张牌,直到一方没有牌 queue容器:模拟上述过程,当次数达到最大值时判断为-1 */ #include <cstdio&g ...

  8. 贪心 Codeforces Round #304 (Div. 2) B. Soldier and Badges

    题目传送门 /* 题意:问最少增加多少值使变成递增序列 贪心:排序后,每一个值改为前一个值+1,有可能a[i-1] = a[i] + 1,所以要 >= */ #include <cstdi ...

  9. 水题 Codeforces Round #304 (Div. 2) A. Soldier and Bananas

    题目传送门 /* 水题:ans = (1+2+3+...+n) * k - n,开long long */ #include <cstdio> #include <algorithm ...

随机推荐

  1. matlab实现算术编解码 分类: 图像处理 2014-06-01 23:01 357人阅读 评论(0) 收藏

    利用Matlab实现算术编解码过程,程序如下: clc,clear all; symbol=['abc']; pr=[0.4 0.4 0.2]; %各字符出现的概率 temp=[0.0 0.4 0.8 ...

  2. Android偏好设置(1)概述和Preferences简介

    1.Overview Instead of using View objects to build the user interface, settings are built using vario ...

  3. domain admin域管理员

    当计算机加入到域后,默认将"Domain Admins"组赋予了本地系统管理员的权限.也就是说,在计算机添加到域,成为域的成员主机的过程中,系统将会自动把"Domain ...

  4. SQL Server Management Studio 手动导入Excel文件

    SQL Server Management Studio(企业管理器) 手动导入Excel文件,有时间还是非常方便的,省去了写代码的麻烦. 具体步骤如下: 下面附上 创建游标的方法(用于循环读取临时表 ...

  5. String的用法——转换功能

    package cn.itcast_05; /* String类的转换功能: byte[] getByte():把字符串转换成字节数组 复习: public String(byte[] bytes): ...

  6. python_函数的可变参数

    def test(*args,**kwargs): print(args) print(kwargs) test(1,2,3,x=1,y=2) 运行结果: *args称为positional argu ...

  7. Friday Q&A 2015-11-20:协变与逆变

    作者:Mike Ash,原文链接,原文日期:2015-11-20译者:Cee:校对:千叶知风:定稿:numbbbbb 在现代的编程语言中,子类型(Subtypes)和超类型(Supertypes)已经 ...

  8. Python_练习_VS清理器

    #导入os import os #创建列表放入后缀 d=[ '.txt','obj','tlog','lastbuildstate','idb','pdb','pch','res','ilk','sd ...

  9. li标签和checkbox绑定

    参考原文:https://www.cnblogs.com/youxin/p/3885496.html 我们经常需要li或span包含一个checkbox,不管点击checkbox或li都会触发相应的事 ...

  10. 基于短语的统计机器翻(PBMT) 开源工具 :Moses

    如何运行Moses 1. Moses的历史 Moses是Pharaoh的升级版本,增加了许多功能.它是一个基于短语的统计机器翻译系统,整个系统用C++语言写成,从训练到解码完全开放源代码,可以运行在L ...