2018.11.7 PION 模拟赛

期望:100 + 80 + 75 = 255

实际:0 + 80 + 60 = 140

唉~一天比一天犯的错误智障,感觉noip要凉啊。。。

吓得我赶紧吃几颗药补补脑子。

奶一下大佬:

  lgj AK NOIP    zbq AK NOIP     gxb AK NOIP    

  mjt AK NOIP     zzx AK NOIP      wcz AK  NOIP

是的,我什么也没写。QwQ(逃~~~~)

唉~数论学的不行啊!!

后来发现我的T1的0分到100分只有一个memset(vis,0,sizeof(vis))的距离。

mdzz vis数组忘了清零了。

/*
最后形成的联通块的数量,就是n,m,k的最大公约数。
这是显然的。
只要确定每一个联通块都被访问过就可以了。 
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int T;
int b,g,t;
long long n,m,k;
bool vis[20000000];
long long gcd(long long x,long long y){
    return x==0?y:gcd(y%x,x);
}
int main(){
    freopen("happy2.in","r",stdin);
    freopen("happy2.out","w",stdout);
    scanf("%d",&T);
    while(T--){
        bool f=0;
        cin>>n>>m>>k;
        long long G;
        if(n!=0&&m!=0&&k!=0){ G=gcd(n,gcd(m,k));}
        else if(k==0&&n!=0&&m!=0){ G=gcd(n,m);}
        else if(m!=0&&n!=0&&k!=0){ G=gcd(n,k);}
        else if(n!=0&&k!=0&&m!=0){ G=gcd(k,m);}
        else if(n!=0&&m==0&&k==0){ G=n;}
        else if(m!=0&&n==0&&k==0){ G=m;}
        else if(k!=0&&m==0&&n==0){ G=k;}
        scanf("%d",&b);
        for(int i=1;i<=b;i++){
            int x;cin>>x;x%=G;
            vis[x]=1;
        }
        scanf("%d",&g);
        for(int i=1;i<=g;i++){
            int x;cin>>x;x%=G;
            vis[x]=1;
        }
        scanf("%d",&t);
        for(int i=1;i<=t;i++){
            int x;cin>>x;x%=G;
            vis[x]=1;
        }
        for(int i=0;i<G;i++)
            if(!vis[i]){
                puts("No");f=1;
                break;
            }
        if(f==0)    puts("Yes");
    }
}
写挂了的正解
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int T,n,m,k,b,g,t;
int fa[6010],vis[6010];
int idb[100010],idg[100010],idt[100010];
int read(){
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
    return x*f;
}
int gcd(int x,int y){
    return x==0?y:gcd(y%x,x);
}
int find(int x){
    if(fa[x]==x)    return x;
    return fa[x]=find(fa[x]);
}
int main(){
    freopen("happy2.in","r",stdin);
    freopen("happy2bao.out","w",stdout); 
    T=read();
    while(T--){
        n=read();m=read();k=read();
        b=read();
        for(int i=1;i<=b;i++)    idb[i]=read();
        g=read();
        for(int i=1;i<=g;i++)    idg[i]=read();
        t=read();
        for(int i=1;i<=t;i++)    idt[i]=read();
        if(n<=2000){
            bool f=0;
            for(int i=0;i<m+n+k;i++)    fa[i]=i;
            int G,LCM;
            if(n!=0&&m!=0&&k!=0){ G=gcd(n,gcd(m,k));LCM=n/G*m/G*k; }
            else if(k==0&&n!=0&&m!=0){ G=gcd(n,m);LCM=n/G*m; }
            else if(m!=0&&n!=0&&k!=0){ G=gcd(n,k);LCM=n/G*k; }
            else if(n!=0&&k!=0&&m!=0){ G=gcd(k,m);LCM=k/G*m; }
            else if(n!=0&&m==0&&k==0){ G=n;LCM=n;}
            else if(m!=0&&n==0&&k==0){ G=m;LCM=m;}
            else if(k!=0&&m==0&&n==0){ G=k;LCM=k;}
            for(int i=0;i<LCM;i++){
                int a,b,c,da,db,dc; 
                if(n!=0)    a=i%n;
                if(m!=0)    b=i%m+n;
                if(k!=0)    c=i%k+n+m;
                if(n!=0)    da=find(a);
                if(m!=0)    db=find(b);
                if(n!=0&&m!=0&&da!=db)    fa[da]=db;
                if(m!=0)    db=find(b);
                if(k!=0)    dc=find(c);
                if(m!=0&&k!=0&&db!=dc)    fa[db]=dc;
                if(n!=0)    da=find(a);
                if(k!=0)    dc=find(c);
                if(n!=0&&k!=0&&da!=dc)    fa[da]=dc;
            }
            for(int i=1;i<=b;i++)    vis[find(idb[i])]=1;
            for(int i=1;i<=g;i++)    vis[find(idg[i]+n)]=1;
            for(int i=1;i<=t;i++)    vis[find(idt[i]+n+m)]=1;
            for(int i=0;i<n+m+k;i++)
                if(find(i)==i&&vis[i]==0){
                    puts("No");f=1;
                    break;
                }
            if(f==0)    puts("Yes");
        }
    }
}
写挂了的50分暴力
/*
最后形成的联通块的数量,就是n,m,k的最大公约数。
这是显然的。
只要确定每一个联通块都被访问过就可以了。 
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int T;
int b,g,t;
long long n,m,k;
bool vis[20000000];
long long gcd(long long x,long long y){
    return x==0?y:gcd(y%x,x);
}
int main(){
    freopen("happy2.in","r",stdin);
    freopen("happy2.out","w",stdout);
    scanf("%d",&T);
    while(T--){
        bool f=0;
        cin>>n>>m>>k;
        long long G;
        if(n!=0&&m!=0&&k!=0){ G=gcd(n,gcd(m,k));}
        else if(k==0&&n!=0&&m!=0){ G=gcd(n,m);}
        else if(m!=0&&n!=0&&k!=0){ G=gcd(n,k);}
        else if(n!=0&&k!=0&&m!=0){ G=gcd(k,m);}
        else if(n!=0&&m==0&&k==0){ G=n;}
        else if(m!=0&&n==0&&k==0){ G=m;}
        else if(k!=0&&m==0&&n==0){ G=k;}
        scanf("%d",&b);
            if(n==30&&m==42){
                int hh=1;
            }
        for(int i=1;i<=b;i++){
            int x;cin>>x;x%=G;
            vis[x]=1;
        }
        scanf("%d",&g);
        for(int i=1;i<=g;i++){
            int x;cin>>x;x%=G;
            vis[x]=1;
        }
        scanf("%d",&t);
        for(int i=1;i<=t;i++){
            int x;cin>>x;x%=G;
            vis[x]=1;
        }
        for(int i=0;i<G;i++)
            if(!vis[i]){
                puts("No");f=1;
                break;
            }
        if(f==0)    puts("Yes");
        memset(vis,0,sizeof(vis));
    }
}
100

/*
期望得分:80 
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int p;
long long n,ans;
bool vi[300010];
int yes[300010];
int vis[1010][1010];
struct nond{ int x,y; }v[300010];
int read(){
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
    return x*f;
}
bool judge(int a,int b){
    int sum=yes[a]+yes[b]-vis[a][b];
    if(sum>=p)    return true;
    else return false;
}
int main(){
//    freopen("lpp.in","r",stdin);
    freopen("suspect.in","r",stdin);
    freopen("suspect.out","w",stdout);
    cin>>n;p=read();
    for(int i=1;i<=n;i++){
        v[i].x=read();
        v[i].y=read();
        if(v[i].x>v[i].y)    swap(v[i].x,v[i].y);
    }
    if(p==0){
        ans=n*(n-1)/2;
        cout<<ans;
    }
    else if(p==1){
        long long tot=0;
        for(int i=1;i<=n;i++){
            if(!vi[v[i].x]){ vi[v[i].x]=1;tot++; }
            if(!vi[v[i].y]){ vi[v[i].y]=1;tot++; }
        }
        long long last=n-tot;
        ans=n*(n-1)/2-last*(last-1)/2;
        cout<<ans;
    }
    else if(n<=1000){
        for(int i=1;i<=n;i++){
            yes[v[i].x]++;
            yes[v[i].y]++;
            vis[v[i].x][v[i].y]++;
        }
        for(int i=1;i<=n;i++)
            for(int j=i+1;j<=n;j++)
                if(judge(i,j))    ans++;
        cout<<ans;
    }
}
80分暴力

 

/*
期望得分:75 
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,m;
int sum[1010][1010];
int sum0[300010],sum1[300010];
int a[300010],b[300010],num[300010];
int read(){
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
    return x*f;
}
int main(){
    freopen("xor.in","r",stdin);
    freopen("xor.out","w",stdout);
    n=read();int num1=0;
    for(int i=1;i<=n;i++){
        scanf("%d",&a[i]);
        b[i]=a[i];
        if(a[i]<=1)    num1++;
    }
    sort(b+1,b+1+n);
    int bnum=unique(b+1,b+1+n)-b-1;
    if(bnum==n){
        m=read();
        for(int i=1;i<=m;i++){
            int l=read();int r=read();
            puts("0");
        }
    }
    else if(num1==n){
        for(int i=1;i<=n;i++){
            if(a[i]==1){
                sum0[i]=sum0[i-1];
                sum1[i]=sum1[i-1]+1;
            }
            if(a[i]==0){
                sum1[i]=sum1[i-1];
                sum0[i]=sum0[i-1]+1;
            }
        }
        m=read();
        for(int i=1;i<=m;i++){
            int l=read();int r=read();
            int xx=sum1[r]-sum1[l-1];
            int yy=sum0[r]-sum0[l-1];
            if(xx%2==0&&yy%2==0&&xx!=0&&yy!=0) puts("1");
            else if(xx%2==0&&xx!=0)    puts("1");
            else if(yy%2==0&&yy!=0)    puts("0");
            else puts("0");//漏下的情况 
        }
    }
    else if(n<=1000){
        for(int i=1;i<=n;i++){
            int x=a[i];
            a[i]=lower_bound(b+1,b+1+bnum,a[i])-b;
            num[a[i]]=x;
        }
        for(int i=1;i<=n;i++)
            for(int j=1;j<=bnum;j++){
                if(a[i]==j)    sum[i][j]=sum[i-1][j]+1;
                else sum[i][j]=sum[i-1][j];
            }
        m=read();
        for(int i=1;i<=m;i++){
            int l=read();int r=read();
            int ans=0;
            for(int j=1;j<=bnum;j++){
                int xx=sum[r][j]-sum[l-1][j];
                if(xx%2==0&&xx!=0)    ans=ans^num[j];
            }
            printf("%d\n",ans);
        }
    }
}
/*
7
1 0 0 1 1 0 0
5
4 7
4 5
1 3
1 7
1 5
*/
80分暴力

 

转载于:https://www.cnblogs.com/cangT-Tlan/p/9923513.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值