清北刷题冲刺 10-28 a.m

立方数

(cubic)

Time Limit:1000ms   Memory Limit:128MB

 

题目描述

LYK定义了一个数叫“立方数”,若一个数可以被写作是一个正整数的3次方,则这个数就是立方数,例如1,8,27就是最小的3个立方数。

现在给定一个数P,LYK想要知道这个数是不是立方数。

当然你有可能随机输出一些莫名其妙的东西来骗分,因此LYK有T次询问~

 

输入格式(cubic.in)

    第一行一个数T,表示有T组数据。

    接下来T行,每行一个数P。

 

输出格式(cubic.out)

输出T行,对于每个数如果是立方数,输出“YES”,否则输出“NO”。

 

输入样例

3

8

27

28

 

输出样例

YES

YES

NO

 

数据范围

对于30%的数据p<=100。

对于60%的数据p<=10^6。

对于100%的数据p<=10^18,T<=100。

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
struct node{
    long long v;
    int id;
    bool ok;
}q[110];
bool cmp1(node x,node y){return x.v<y.v;}
bool cmp2(node x,node y){return x.id<y.id;}
long long qread(){
    long long i=0;
    char ch=getchar();
    while(ch<'0'||ch>'9')ch=getchar();
    while(ch<='9'&&ch>='0')i=i*10+ch-'0',ch=getchar();
    return i;
}
int T;
int main(){
    freopen("cubic.in","r",stdin);freopen("cubic.out","w",stdout);
//    freopen("Cola.txt","r",stdin);
    scanf("%d",&T);
    for(int i=1;i<=T;i++){
        q[i].v=qread();
        q[i].id=i;
    }
    sort(q+1,q+T+1,cmp1);
    int l=1;
    for(int i=1;i<=1000000;i++){
        long long now=1LL*i*i*i;
        if(now>q[T].v)break;
        while(now==q[l].v)q[l].ok=1,l++;
        while(now>q[l].v)l++;
        while(now==q[l].v)q[l].ok=1,l++;
        if(l>T)break;
    }
    sort(q+1,q+T+1,cmp2);
    for(int i=1;i<=T;i++){
        if(q[i].ok)puts("YES");
        else puts("NO");
    }
    fclose(stdin);fclose(stdout);
    return 0;
}
100分

立方数2

(cubicp)

Time Limit:1000ms   Memory Limit:128MB

 

题目描述

LYK定义了一个数叫“立方数”,若一个数可以被写作是一个正整数的3次方,则这个数就是立方数,例如1,8,27就是最小的3个立方数。

LYK还定义了一个数叫“立方差数”,若一个数可以被写作是两个立方数的差,则这个数就是“立方差数”,例如7(8-1),26(27-1),19(27-8)都是立方差数。

现在给定一个数P,LYK想要知道这个数是不是立方差数。

当然你有可能随机输出一些莫名其妙的东西,因此LYK有T次询问~

这个问题可能太难了…… 因此LYK规定P是个质数!

 

输入格式(cubicp.in)

    第一行一个数T,表示有T组数据。

    接下来T行,每行一个数P。

 

输出格式(cubicp.out)

输出T行,对于每个数如果是立方差数,输出“YES”,否则输出“NO”。

 

输入样例

5

2

3

5

7

11

 

输出样例

NO

NO

NO

YES

NO

 

 

数据范围

对于30%的数据p<=100。

对于60%的数据p<=10^6。

对于100%的数据p<=10^12,T<=100。

 

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n;
struct node{
    long long v;
    int id;
    bool ok;
}q[110];
bool cmp1(node x,node y){return x.v<y.v;}
bool cmp2(node x,node y){return x.id<y.id;}
long long qread(){
    long long i=0;
    char ch=getchar();
    while(ch<'0'||ch>'9')ch=getchar();
    while(ch<='9'&&ch>='0')i=i*10+ch-'0',ch=getchar();
    return i;
}
int main(){
    freopen("cubicp.in","r",stdin);freopen("cubicp.out","w",stdout);
    scanf("%d",&n);
    for(int i=1;i<=n;i++)q[i].v=qread(),q[i].id=i;
    sort(q+1,q+n+1,cmp1);
    int l=1;
    for(int i=1;i<=1000000;i++){
        int j=i+1;
        long long now=1LL*i*i+1LL*i*j+1LL*j*j;
        if(now>q[n].v)break;
        while(now==q[l].v)q[l].ok=1,l++;
        while(now>q[l].v)l++;
        while(now==q[l].v)q[l].ok=1,l++;
        if(l>n)break;
    }
    sort(q+1,q+n+1,cmp2);
    for(int i=1;i<=n;i++){
        if(q[i].ok)puts("YES");
        else puts("NO");
    }
    fclose(stdin);fclose(stdout);
    return 0;
}
100分

 

猜数字

(number)

Time Limit:1000ms   Memory Limit:128MB

 

题目描述

    LYK在玩猜数字游戏。

    总共有n个互不相同的正整数,LYK每次猜一段区间的最小值。形如[li,ri]这段区间的数字的最小值一定等于xi。

    我们总能构造出一种方案使得LYK满意。直到…… LYK自己猜的就是矛盾的!

    例如LYK猜[1,3]的最小值是2,[1,4]的最小值是3,这显然就是矛盾的。

    你需要告诉LYK,它第几次猜数字开始就已经矛盾了。

 

输入格式(number.in)

    第一行两个数n和T,表示有n个数字,LYK猜了T次。
    接下来T行,每行三个数分别表示li,ri和xi。

 

输出格式(number.out)

输出一个数表示第几次开始出现矛盾,如果一直没出现矛盾输出T+1。

 

输入样例

20 4

1 10 7

5 19 7

3 12 8

1 20 1

 

输出样例

3

 

数据范围

对于50%的数据n<=8,T<=10。

对于80%的数据n<=1000,T<=1000。

对于100%的数据1<=n,T<=1000000,1<=li<=ri<=n,1<=xi<=n(但并不保证一开始的所有数都是1~n的)。

 

Hint

建议使用读入优化

inline int read()

{

       int x = 0, f = 1;

       char ch = getchar();

       for(; !isdigit(ch); ch = getchar()) if(ch == '-') f = -1;

       for(; isdigit(ch); ch = getchar()) x = (x << 1) + (x << 3) + ch - '0';

       return x * f;

}

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 1000010
#define INF 1000001
using namespace std;
int n,T,opv,opx,cnt;
bool use[maxn];
struct node{
    int l,r,v;
    bool operator < (const node x)const{
        if(v!=x.v)return v>x.v;
        if(l!=x.l)return l<x.l;
        if(r!=x.r)return r<x.r;
    }
}a[maxn],b[maxn],qujian[maxn];
int q[maxn];
void change(){
    q[opx]=opv;
}
int find(int l,int r){
    int mn=0x7fffffff;
    for(int i=l;i<=r;i++)mn=min(mn,q[i]);
    return mn;
}
bool flag=0;
int opl,opr;
void dfs(int pos){
    if(flag)return;
    if(pos==cnt+1){
        if(find(opl,opr)<opv)return;
        flag=1;return;
    }
    for(int i=qujian[pos].l;i<=qujian[pos].r;i++){
        if(q[i]<1000000)continue;
        int w=q[i];
        q[i]=qujian[pos].v;
        dfs(pos+1);
        if(flag)return;
        q[i]=w;
    }
}
bool check(int x){
    cnt=0;
    memset(q,0x7f,sizeof(q));
    memset(use,0,sizeof(use));
    for(int i=1;i<=x-1;i++)b[i]=a[i];
    sort(b+1,b+x);
    int l=0,r=0x7fffffff,vnow;
    for(int i=1;i<=x-1;i++){
        if(i==1||b[i].v!=b[i-1].v){
            if(i!=1){
                qujian[++cnt].l=l;
                qujian[cnt].r=r;
                qujian[cnt].v=vnow;
            }
            l=0,r=0x7fffffff;
        }
        l=max(l,b[i].l),r=min(r,b[i].r);
        vnow=b[i].v;
        if(l>r)return 1;//不合法 
    }
    cnt=cnt+1;
    qujian[cnt].l=l;
    qujian[cnt].r=r;
    qujian[cnt].v=vnow;
    opl=a[x].l,opr=a[x].r;opv=a[x].v;
    flag=0;
    dfs(1);
    if(flag==0)return 1;
    return 0;
}
int int_qread(){
    int i=0;
    char ch=getchar();
    while(ch<'0'||ch>'9')ch=getchar();
    while(ch<='9'&&ch>='0')i=i*10+ch-'0',ch=getchar();
    return i;
}
int main(){
//    freopen("Cola.txt","r",stdin);
    freopen("number.in","r",stdin);freopen("number.out","w",stdout);
    n=int_qread();T=int_qread();
    for(int i=1;i<=T;i++){
        a[i].l=int_qread();
        a[i].r=int_qread();
        a[i].v=int_qread();
    }
    int ans=T+1;
    for(int i=2;i<=T;i++){
        if(check(i)){
            ans=i;
            break;
        }
    }
    printf("%d",ans);
    fclose(stdin);fclose(stdout);
    return 0;
}
40分 暴力
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 1000010
using namespace std;
int n,q,ans;
int fa[maxn];
struct node{
    int l,r,v;
}p[maxn],t[maxn];
int qread(){
    int i=0;
    char ch=getchar();
    while(ch<'0'||ch>'9')ch=getchar();
    while(ch<='9'&&ch>='0')i=i*10+ch-'0',ch=getchar();
    return i;
}
bool cmp(node x,node y){return x.v>y.v;}
int find(int x){
    if(x==fa[x])return x;
    return fa[x]=find(fa[x]);
}
bool check(int k){
    int lmn,lmx,rmn,rmx;
    for(int i=1;i<=n+1;i++)fa[i]=i;
    for(int i=1;i<=k;i++)t[i]=p[i];
    sort(t+1,t+k+1,cmp);
    lmn=lmx=t[1].l;
    rmn=rmx=t[1].r;
    for(int i=2;i<=k;i++){
        if(t[i].v<t[i-1].v){
            if(find(lmx)>rmn)return 1;
            for(int j=find(lmn);j<=rmx;j++)
                fa[find(j)]=find(rmx+1);
            lmn=lmx=t[i].l;
            rmn=rmx=t[i].r;
        }
        else{
            lmn=min(lmn,t[i].l);
            lmx=max(lmx,t[i].l);
            rmn=min(rmn,t[i].r);
            rmx=max(rmx,t[i].r);
            if(lmx>rmn)return 1;
        }
    }
    if(find(lmx)>rmn)return 1;
    return 0;
}
int main(){
    freopen("number.in","r",stdin);freopen("number.out","w",stdout);
    int l,r,mid;
    n=qread();q=qread();
    for(int i=1;i<=q;i++)
        p[i].l=qread(),p[i].r=qread(),p[i].v=qread();
    l=1,r=q;ans=q+1;
    while(l<=r){
        mid=(l+r)>>1;
        if(check(mid))ans=mid,r=mid-1;
        else l=mid+1;
    }
    printf("%d",ans);
}
100分 并查集

 

 

预计得分100+100+50
实际得分100+0+0
T2有一句话忘写了,导致输出顺序错误
T3有一个无用数祖忘删了,爆了空间
这次考试太不谨慎
把不该犯的错误改过来之后是100+100+40
小结

 

posted @ 2017-10-28 10:06  Echo宝贝儿  阅读(395)  评论(3编辑  收藏  举报