题目链接

输入t对数 a, b

求(b,a]内的每个数拆成素因子的个数和

这里每个数都可以写成素数的乘积,可以写成几个素数的和就有几个素因子,这里求的是(b,a]内的素因子和

思路:

素数的素因子个数是1

对于非素数A的素因子个数 = A/k  + 1 其中k是素数,也是第一个素数,或者K是比A小的数,并且A%k==0

下面是利用K是比A小的数,并且A%k==0

     void solve(){
Scanner sc = new Scanner(System.in);
int t = sc.nextInt();
int a ,b;
int MAX = 5000000;
int[] arr=new int[MAX+1];
for(int i=2;i<=MAX;i++){
if(i%2==0){
arr[i] = arr[i/2]+1;
continue;
}
for(int j=3;j*j<=i;j+=2){
int k=i/j;
if(k*j==i){
arr[i] = arr[k] + 1;
break;
}
}
if (arr[i]==0)
arr[i] = 1;
}
for(int i=2;i<=MAX;i++)
arr[i]+=arr[i-1];
while(t!=0){
a = sc.nextInt();
b = sc.nextInt();
System.out.println(arr[a]-arr[b]);
t--;
}
}

这个读数据效率低,造成运行时间超时

这个是利用素数的,找到第一个素数K,并且A%k==0

    void solve3() throws NumberFormatException, IOException{
int limit = 5000005;
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
int t=Integer.parseInt(br.readLine());
StringTokenizer st;
int div[] = new int[limit];
boolean isPrime[] = new boolean[limit];
int prime[] = new int[limit];
int p=0;
for(int i=2;i<limit;i++){
if(!isPrime[i])
prime[p++]=i;
for(int j=0;j<p &&i*prime[j]<limit;j++){
isPrime[i*prime[j]] = true;
if(i%prime[j]==0)
break;
}
}
for(int i=2;i<limit;i++){
int k = i;
if(!isPrime[i]){
div[i] = 1;
continue;
}
for(int j=0;j<p;j++){
if(k%prime[j]==0){
div[i] = div[k/prime[j]] + 1;
break;
}
}
}
for(int i=2;i<limit;i++)
div[i] += div[i-1];
StringBuilder sb=new StringBuilder();
for(int i=0;i<t;i++){
st=new StringTokenizer(br.readLine());
int a=Integer.parseInt(st.nextToken());
int b=Integer.parseInt(st.nextToken());
sb.append(div[a]-div[b]);
sb.append('\n');
}
System.out.print(sb);
}

换了读数据的方式,成功通过,这里利用到,素数筛选法求出素数的集合

参考链接

还有下面一种,都是参考素数筛选法的求解

void solve2() throws NumberFormatException, IOException{
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
int t=Integer.parseInt(br.readLine());
StringTokenizer st;
int limit = 5000000;
boolean[] array = new boolean[limit+1];
int div[] = new int[limit+1];
for(int i=2;i<=limit;i++){
if(array[i]) continue;
for(int j=i;j<=limit;j+=i){
array[j] = true;
int k=j;
int temp=0;
while(k%i==0){
k/=i;
temp++;
}
div[j]+=temp; }
}
for(int i=1;i<=limit;i++)
div[i]+=div[i-1];
StringBuilder sb=new StringBuilder();
for(int i=0;i<t;i++){
st=new StringTokenizer(br.readLine());
int a=Integer.parseInt(st.nextToken());
int b=Integer.parseInt(st.nextToken());
sb.append(div[a]-div[b]);
sb.append('\n');
}
System.out.print(sb);
}
全部程序如下
package codeforces;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
public class D546 { void run() throws NumberFormatException, IOException{
// solve();// 超时
solve3();
}
void solve3() throws NumberFormatException, IOException{
int limit = 5000005;
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
int t=Integer.parseInt(br.readLine());
StringTokenizer st;
int div[] = new int[limit];
boolean isPrime[] = new boolean[limit];
int prime[] = new int[limit];
int p=0;
for(int i=2;i<limit;i++){
if(!isPrime[i])
prime[p++]=i;
for(int j=0;j<p &&i*prime[j]<limit;j++){
isPrime[i*prime[j]] = true;
if(i%prime[j]==0)
break;
}
}
for(int i=2;i<limit;i++){
int k = i;
if(!isPrime[i]){
div[i] = 1;
continue;
}
for(int j=0;j<p;j++){
if(k%prime[j]==0){
div[i] = div[k/prime[j]] + 1;
break;
}
}
}
for(int i=2;i<limit;i++)
div[i] += div[i-1];
StringBuilder sb=new StringBuilder();
for(int i=0;i<t;i++){
st=new StringTokenizer(br.readLine());
int a=Integer.parseInt(st.nextToken());
int b=Integer.parseInt(st.nextToken());
sb.append(div[a]-div[b]);
sb.append('\n');
}
System.out.print(sb);
} void solve2() throws NumberFormatException, IOException{
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
int t=Integer.parseInt(br.readLine());
StringTokenizer st;
int limit = 5000000;
boolean[] array = new boolean[limit+1];
int div[] = new int[limit+1];
for(int i=2;i<=limit;i++){
if(array[i]) continue;
for(int j=i;j<=limit;j+=i){
array[j] = true;
int k=j;
int temp=0;
while(k%i==0){
k/=i;
temp++;
}
div[j]+=temp; }
}
for(int i=1;i<=limit;i++)
div[i]+=div[i-1];
StringBuilder sb=new StringBuilder();
for(int i=0;i<t;i++){
st=new StringTokenizer(br.readLine());
int a=Integer.parseInt(st.nextToken());
int b=Integer.parseInt(st.nextToken());
sb.append(div[a]-div[b]);
sb.append('\n');
}
System.out.print(sb);
} void solve(){
Scanner sc = new Scanner(System.in);
int t = sc.nextInt();
int a ,b;
int MAX = 5000000;
int[] arr=new int[MAX+1];
for(int i=2;i<=MAX;i++){
if(i%2==0){
arr[i] = arr[i/2]+1;
continue;
}
for(int j=3;j*j<=i;j+=2){
int k=i/j;
if(k*j==i){
arr[i] = arr[k] + 1;
break;
}
}
if (arr[i]==0)
arr[i] = 1;
}
for(int i=2;i<=MAX;i++)
arr[i]+=arr[i-1];
while(t!=0){
a = sc.nextInt();
b = sc.nextInt();
System.out.println(arr[a]-arr[b]);
t--;
}
} public static void main(String[] args) throws NumberFormatException, IOException { new D546().run(); } }

Codeforces D546:Soldier and Number Game的更多相关文章

  1. CodeForces 546 D. Soldier and Number Game(素数有关)

    Description Two soldiers are playing a game. At the beginning first of them chooses a positive integ ...

  2. 【codeforces 546D】Soldier and Number Game

    time limit per test3 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  3. 网络流(最大流) CodeForces 546E:Soldier and Traveling

    In the country there are n cities and m bidirectional roads between them. Each city has an army. Arm ...

  4. Codeforces J. Soldier and Number Game(素数筛)

    题目描述: Soldier and Number Game time limit per test 3 seconds memory limit per test 256 megabytes inpu ...

  5. 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 ...

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

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

  7. 数学+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;再来一个前缀和 */ /***************** ...

  8. 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 ...

  9. 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 ...

随机推荐

  1. Java内存溢出详解

    转自:http://elf8848.iteye.com/blog/378805 一.常见的Java内存溢出有以下三种: 1. java.lang.OutOfMemoryError: Java heap ...

  2. php 文件上传简单类---限制仅上传jpg文件

    php 文件上传代码,限制只能上传jpg格式文件,也可以自行添加其它扩展名的文件. <?php /* * 图片上传类 仅限JPG格式图片 * edit by www.jbxue.com at 2 ...

  3. Vim一些实用的用法

    打开多个文件: 1.vim还没有启动的时候:在终端里输入 vim file1 file2 ... filen便可以打开所有想要打开的文件2.vim已经启动输入:open file可以再打开一个文件,并 ...

  4. 开发流程习惯的养成—TFS简单使用

    才开始用,所以是个很基础的介绍,欢迎大家一起交流学习 一.追本溯源 讲到开发流程,还要从敏捷开始,因为敏捷才有了开发流程的重视,整个流程也是按照敏捷的思想进行的,这里不再叙述敏捷的定义 敏捷的流程(个 ...

  5. 如何在64位的Windows中安裝PLSQLDEVELOPER 8

    先到 Oracle 官網下載Oracle Database 11g Release 2 Client (11.2.0.1.0) for Microsoft Windows (x64) ,接者依照以下步 ...

  6. flash builder Error #2032

    flash builder编译时flash player报错:"Error #2032". 解决办法:在菜单栏的 项目-->属性-->构建路径,不要勾选“在调试时使用本 ...

  7. Codeforces Round #238 (Div. 2) D. Toy Sum 暴搜

    题目链接: 题目 D. Toy Sum time limit per test:1 second memory limit per test:256 megabytes 问题描述 Little Chr ...

  8. 使用maven多模块来构建系统时,spring初始化报错的问题

    最近在实验maven结构的maven工程时,碰到一个问题,springbean总是初始化失败: Related cause: org.springframework.beans.factory.Uns ...

  9. html利用锚点实现定位代码实例

    本章节介绍介绍一下如何利用锚点实现定位,使用锚点实现定位是html固有的功能,当然比较简单,也实现了基本的功能,但是功能相对简单一些,如果想要实现平滑的定位可以参阅jquery实现的点击页面动画方式平 ...

  10. Matlab中min/max函数的误解

    1.C= min(a):返回最小值:我原来以为如果a是行向量,min(a)返回a本身,因为我记得min(a,1)是按列找最小,这是默认的.doc min发现,只要a是向量,那么返回最小值. 2.C= ...