P1865 A % B Problem
(一道很水的题)
(反正我第一眼看的时候也是这么想的)
题目背景
题目名称是吸引你点进来的
实际上该题还是很水的
题目描述
区间质数个数
输入输出格式
输入格式:
一行两个整数 询问次数n,范围m
接下来n行,每行两个整数 l,r 表示区间
输出格式:
对于每次询问输出个数 t,如l或r∉[1,m]输出 Crossing the line
输入输出样例
说明
【数据范围和约定】
对于20%的数据 1<=n<=10 1<=m<=10
对于100%的数据 1<=n<=1000 1<=m<=1000000 -10^9<=l<=r<=10^9 1<=t<=1000000
-----------------------------------------------------------------------------------------------------------------
第一眼一看的时候
特别开心
这不就是求素数嘛!
看了一眼数据范围
还可以
用线性的欧拉筛应该可以
于是上手就写
(我才不会说我写了两遍,第二边上的时候思路才定下来)
好不容易写完了
结果输入数不进去
a[++l]写成了a[l++]
于是进入了死循环
哎
好不容易过了样例
一提交t了5个点
啊哈??
不是线性的吗??(顿时懵逼)
于是看题解了(千万千万不要这样,动不动就看题解,真的是很不好的习惯)
题解居然是埃氏筛
啊哈??
再一看代码果然
先放一个我错误的代码!!!!!
以此为耻
#include<cstdio>
using namespace std;
long long n,m,a[],b[],c[],ans,len; //a存每个区间的素数个数,b存素数
long long l,r; inline long long read()
{
long long ans = ;
int p = ;
char ch = getchar();
while(ch < '' || ch > '')
{
if(ch == '-')
p = -;
ch = getchar();
}
while(ch >= ''&&ch <='')
{
(ans *= )+= ch-'';
ch = getchar();
}
return ans * p;
} int main()
{
a[] = ;
a[] = ;
b[] = ;
c[] = ;//0为不是
c[] = ;// 1为是
len = ;
n = read();
m = read(); for(long long i=;i<=m;i++)//遍历每个数
for(long long j=;j<=len;j++)//看他能不能被素数整除
{
if(i % b[j]== ) //被素数整除
{
a[i]=a[i-];
break;
}
else
if(j == len)//全用素数除过了
{
c[i] = ;
a[i] = a[i - ] + ;
b[++len] = i;
break;
}
} for(long long i = ;i <= n;i++)
{
l = read();
r = read();
if(l>=&&r <= m)//在范围内
{
if(c[l] == )
{
printf("%lld\n",a[r] - a[l]+);
}
else
{
printf("%lld\n",a[r]-a[l]);
}
}
else
printf("Crossing the line\n");
}
return ;
}
哎确实是循环多了好多
还是放题解!!!!!!
#include<bits/stdc++.h>
using namespace std; int f[];
bool vis[]; void shai(int n)
{
f[]=;
vis[]=true;
for(int i=;i<=n;i++)
{
if(vis[i]==false) //在筛里进行前缀和
{
f[i]=f[i-]+;//前缀和计算 这处
for(int j=i+i;j<=n;j=j+i)
{
vis[j]=true;//标记操作
}
}
else f[i]=f[i-];//前缀和转移 和这处就很妙了
}
} int main()
{
int n,m;
scanf("%d%d",&m,&n);
shai(n);
for(int i=;i<=m;i++)
{
int l,r;
scanf("%d%d",&l,&r);
if(l< || r>n) cout<<"Crossing the line"<<endl;//判断是否超出区间
else
{
int y=f[r]-f[l-];//此处已经修改
cout<<y<<endl;
}
}
return ;
}
换个角度从判断素数,变成判断合数;
埃氏筛
本质上就是从2开始把它除本身的倍数全部删去,以此类推
区间和可以用前缀和处理;
P1865 A % B Problem的更多相关文章
- 洛谷P1865 A % B Problem
1.洛谷P1865 A % B Problem 题目背景 题目名称是吸引你点进来的 实际上该题还是很水的 题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行 ...
- 【luogu P1865 A % B Problem】 题解
题目链接:https://www.luogu.org/problemnew/show/P1865 其实就是埃拉托色尼筛素数模板... 好像每个数暴力枚举到sqrt()也可以...就算当我无聊练手罢 # ...
- [线性筛]P1865 A % B Problem
题目背景 题目名称是吸引你点进来的 实际上该题还是很水的 题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行,每行两个整数 l,r 表示区间 输出格式: 对 ...
- 【数论线性筛】洛谷P1865 A%B problem
题目背景 题目名称是吸引你点进来的 实际上该题还是很水的 题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行,每行两个整数 l,r 表示区间 输出格式: 对 ...
- P1865 A % B Problem 素数筛
题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行,每行两个整数 l,r 表示区间 输出格式: 对于每次询问输出个数 t,如l或r∉[1,m]输出 Cros ...
- 洛谷 P1865 A % B Problem
题目戳 题目背景 题目名称是吸引你点进来的 实际上该题还是很水的 题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行,每行两个整数 l,r 表示区间 输出格 ...
- 洛谷 P1865 A % B Problem[筛素数/前缀和思想/区间质数个数]
题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行,每行两个整数 l,r 表示区间 输出格式: 对于每次询问输出个数 t,如l或r∉[1,m]输出 Cros ...
- [Luogu] P1865 A % B Problem
题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行,每行两个整数 l,r 表示区间 输出格式: 对于每次询问输出个数 t,如l或r∉[1,m]输出 Cros ...
- 洛谷 P1865 A % B Problem(求区间质数个数)
题目背景 题目名称是吸引你点进来的 实际上该题还是很水的 题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m 接下来n行,每行两个整数 l,r 表示区间 输出格式: 对 ...
随机推荐
- vue从入门到进阶:指令与事件(二)
一.插值 v-once 通过使用 v-once 指令,你也能执行一次性地插值,当数据改变时,插值处的内容不会更新.但请留心这会影响到该节点上所有的数据绑定: span v-once>这个将不会改 ...
- 网络基础 记一次HTTPS证书验证测试过程
记一次HTTPS证书验证测试过程 by:授客 QQ:1033553122 实践 1) 安装证书 选择主机A(假设10.202.95.88)上安装https证书 说明:采用https的服务器,必须安装数 ...
- Java中的变量与常量
Java中的常量 final 常量名=值; final PI=3.1415; //声明一个常量PI 定义常量:final double PI=3.1415926; Java三大变量分别是 类变量( ...
- Android sdk下载找不到support library
没有android support library下载项. 找了很多资料,发现 android support library 被Google废弃了,不推荐使用.代替使用的是 android supp ...
- PyCharm 如何新建Django工程项目
声明:本文使用的IDE是PyCharm 2018.1.2版. 一.File-New Project 二.选择工程类型 强烈建议选项"Pure Python",因为如果选择" ...
- Android 闪烁动画
import android.view.View; import android.view.animation.AlphaAnimation; import android.view.animatio ...
- Windows Server 2016-Win Ser 2016新增功能
本来想着整个系列都是与Active Directory相关的内容,上一章节我们应读者要求补充了Window Server 2016标准版与数据中心版的区别,鉴于读者的疑惑,从本章节开始补充三到五章与W ...
- 文件服务器HFS
用途:用于文件共享(类似FTP) 官网:http://www.rejetto.com/hfs/?f=ss 优点:比起apache,它有界面方便查看当前正连接的主机 如果在内网环境下进行文件共享的话,可 ...
- Android中使用ViewGroup.removeViews()时出现NullPointException解决方案
在ViewGroup的内部写一个动画效果,在效果结束之后会调用onAnimationEnd(Animation arg0),在此方法中如果直接使用removeViews()时,可能会出现NullPoi ...
- CSS多行文本垂直居中
今天需要将文本垂直居中,就是一行是垂直居中,多行也是垂直居中. 效果如下 实现代码(同事提供) <!DOCTYPE html> <html> <head lang=&qu ...