2016春季练习——二次筛

来源:POJ2689

写了两个小时的题目,最后参考题解了。。。果然几天不写题水平下降。。。

RE的代码:

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int N=50010;
const long long INF=0x7fffffff;
long long prime1[N],np1;
bool isp[N*200];
void make_p1(){
    long long i,j;
    np1=0;
    memset(isp,1,sizeof(isp));
    isp[0]=isp[1]=0;
    for(i=2;i<N;i++){
        if(isp[i]){
            np1++;
            prime1[np1]=i;
            for(j=i*i;j<N;j+=i)
                isp[j]=0;
        }
    }
}
long long l,u;
long long prime2[1000100];
int np2;
void make_p2(){
    long long i,j,b;
    memset(isp,1,sizeof(isp));
    for(i=1;i<=np1;i++){
        b=l/prime1[i];
        while(b*prime1[i]<l||b<=1)
            b++;
        for(j=b*prime1[i];j<=u;j+=prime1[i]){
            if(j>=l)
                isp[j-l]=0;
        }
    }
    if(l==1)
        isp[0]=0;
}
void solve(){
    int i;
    long long mina=INF,maxn=-INF;
    long long minl,minr,maxl,maxr;
    make_p2();
    np2=0;
    for(i=0;i<u;i++){
        if(isp[i]){
            np2++;
            prime2[np2]=i+1;
        }
    }
    if(np2<=l){
        cout<<"There are no adjacent primes."<<endl;
        return ;
    }
    else{
        for(i=1;i<np2;i++){
            if(prime2[i+1]-prime2[i]<mina){
                mina=prime2[i+1]-prime2[i];
                minl=prime2[i],minr=prime2[i+1];
            }
            if(prime2[i+1]-prime2[i]>maxn){
                maxn=prime2[i+1]-prime2[i];
                maxl=prime2[i],maxr=prime2[i+1];
            }
        }
        printf("%lld,%lld are closest, %lld,%lld are most distant.\n",minl,minr,maxl,maxr);
    }
}
int main(){
	make_p1();
	while(scanf("%lld%lld",&l,&u)!=EOF){
        solve();
	}
	return 0;
}
DEBUG没发现问题。。。真是醉了。。。主要是RE,真是不敢相信。

AC代码:

#include <cstdio>
#include <cstring>
#include <cmath>
#include <queue>
#include <iostream>
#include <algorithm>
using namespace std;
const int INF=1e9;
const int maxn=5e4+10;
const int maxm=1e6+10;
int l,u,prime[maxn],vis[maxn],f[maxm],t;
void ini()//求出50000内的素数,int范围内的合数最小质因子必定小于2^16。
{
    int i,j,k,m;
    t=0;
    m=(int)sqrt(maxn+0.5);
    memset(vis,0,sizeof(vis));
    for(i=2;i<=m;i++)
    {
        if(!vis[i])
        {
            for(j=i*i;j<maxn;j+=i)
            vis[j]=1;
        }
    }
    for(i=2;i<maxn;i++)if(!vis[i])prime[t++]=i;
}
int main()
{
    ini();
    while(cin>>l>>u)
    {
        if(l==1)l=2;//注意l=1会出问题。
        int i,j,k,a,b;
        memset(f,0,sizeof(f));
        for(i=0;i<t;i++)
        {
            a=(l-1)/prime[i]+1;
            b=u/prime[i];
            for(j=a;j<=b;j++)if(j>1)f[j*prime[i]-l]=1;//[l,u]区间小于1e6,而l,u数值范围为int,所以偏移l们就能用数组存了
        }
        int p=-1,max_ans=-1,min_ans=INF,x1,y1,x2,y2;
        for(i=0;i<=u-l;i++)//暴力枚举。。
        {
            if(f[i]==0)
            {
                if(p==-1){p=i;continue;}
                if(max_ans<i-p){max_ans=i-p;x1=p+l;y1=i+l;}
                if(min_ans>i-p){min_ans=i-p;x2=p+l;y2=i+l;}
                p=i;
            }
        }
        if(max_ans==-1)cout<<"There are no adjacent primes."<<endl;
        else cout<<x2<<","<<y2<<" are closest, "<<x1<<","<<y1<<" are most distant."<<endl;
    }
    return 0;
}


欢迎使用“可调增益放大器 Multisim”设计资源包!本资源专为电子爱好者、学生以及工程师设计,旨在展示如何在著名的电路仿真软件Multisim环境下,实现一个具有创新性的数字控制增益放大器项目。 项目概述 在这个项目中,我们通过巧妙结合模拟电路与数字逻辑,设计出一款独特且实用的放大器。该放大器的特点在于其增益可以被精确调控,并非固定不变。用户可以通过控制键,轻松地改变放大器的增益状态,使其在1到8倍之间平滑切换。每一步增益的变化都直观地通过LED数码管显示出来,为观察和调试提供了极大的便利。 技术特点 数字控制: 使用数字输入来调整模拟放大器的增益,展示了数字信号对模拟电路控制的应用。 动态增益调整: 放大器支持8级增益调节(1x至8x),满足不同应用场景的需求。 可视化的增益指示: 利用LED数码管实时显示当前的放大倍数,增强项目的交互性和实用性。 Multisim仿真环境: 所有设计均在Multisim中完成,确保了设计的仿真准确性和学习的便捷性。 使用指南 软件准备: 确保您的计算机上已安装最新版本的Multisim软件。 打开项目: 导入提供的Multisim项目文件,开始查看或修改设计。 仿真体验: 在仿真模式下测试放大器的功能,观察增益变化及LED显示是否符合预期。 实验与调整: 根据需要调整电路参数以优化性能。 实物搭建 (选做): 参考设计图,在真实硬件上复现实验。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值