4 条题解

  • 1
    @ 2023-7-8 15:40:58
    #include<bits/stdc++.h>
    using namespace std;
    const int N=100005;
    int rt,tot,fa[N],ch[N][2],val[N],cnt[N],sz[N];
    int fen[100005],money[10005];
    struct Splay{
    	void maintain(int x){
    		sz[x]=sz[ch[x][0]]+sz[ch[x][1]]+cnt[x];
    	}
    	bool get(int x){
    		return x==ch[fa[x]][1];
    	}
    	void clear(int x){
    		ch[x][0]=ch[x][1]=fa[x]=val[x]=sz[x]=cnt[x]=0;
    	}
    	void rotate(int x){
    		int y=fa[x],z=fa[y],chk=get(x);
    		ch[y][chk]=ch[x][chk^1];
    		if(ch[x][chk^1])fa[ch[x][chk^1]]=y;
    		ch[x][chk^1]=y;
    		fa[y]=x;
    		fa[x]=z;
    		if(z)ch[z][y==ch[z][1]]=x;
    		maintain(y);
    		maintain(x);
    	}
    	void splay(int x){
    		for (int f=fa[x];f=fa[x],f;rotate(x)){
    			if(fa[f])rotate(get(x)==get(f)?f:x);
    		}
    		rt=x;
    	}
    	void ins(int k){
    		if(!rt){
    			val[++tot]=k;
    			cnt[tot]++;
    			rt=tot;
    			maintain(rt);
    			return;
    		}
    		int cur=rt,f=0;
    		while(1){
    			if(val[cur]==k){
    				cnt[cur]++;
    				maintain(cur);
    				maintain(f);
    				splay(cur);
    				break;
    			}
    			f=cur;
    			cur=ch[cur][val[cur]<k];
    			if(!cur){
    				val[++tot]=k;
    				cnt[tot]++;
    				fa[tot]=f;
    				ch[f][val[f]<k]=tot;
    				maintain(tot);
    				maintain(f);
    				splay(tot);
    				break;
    			}
    		}
    	}
    	int rk(int k){
    		int res=0,cur=rt;
    		while(1){
    			if(k<val[cur]){
    				cur = ch[cur][0];
    			}
    			else{
    				res+=sz[ch[cur][0]];
    				if(k==val[cur]){
    					splay(cur);
    					return res + 1;
    				}
    				res+=cnt[cur];
    				cur=ch[cur][1];
    			}
    		}
    	}
    	int kth(int k){
    		int cur=rt;
    		while(1){
    			if(ch[cur][0]&&k<=sz[ch[cur][0]]){
    				cur=ch[cur][0];
    			}
    			else{
    				k-=cnt[cur]+sz[ch[cur][0]];
    				if(k<=0){
    					splay(cur);
    					return val[cur];
    				}
    				cur = ch[cur][1];
    			}
    		}
    	}
    	int pre(){
    		int cur=ch[rt][0];
    		if(!cur)return cur;
    		while(ch[cur][1])cur=ch[cur][1];
    		splay(cur);
    		return cur;
    	}
    	int nxt(){
    		int cur=ch[rt][1];
    		if(!cur)return cur;
    		while(ch[cur][0])cur=ch[cur][0];
    		splay(cur);
    		return cur;
    	}
    	void del(int k){
    		rk(k);
    		if(cnt[rt]>1){
    			cnt[rt]--;
    			maintain(rt);
    			return;
    		}
    		if(!ch[rt][0]&&!ch[rt][1]){
    			clear(rt);
    			rt=0;
    			return;
    		}
    		if(!ch[rt][0]){
    			int cur=rt;
    			rt=ch[rt][1];
    			fa[rt]=0;
    			clear(cur);
    			return;
    		}
    		if(!ch[rt][1]){
    			int cur=rt;
    			rt=ch[rt][0];
    			fa[rt]=0;
    			clear(cur);
    			return;
    		}
    		int cur=rt;
    		int x=pre();
    		fa[ch[cur][1]]=x;
    		ch[x][1]=ch[cur][1];
    		clear(cur);
    		maintain(rt);
    	}
    }tree;
    Splay tree2;
    int main(){
    	int a,b,c;
    	cin>>a>>b>>c;
    	tree.ins(a);
    	tree.ins(b);
    	tree.ins(c);
    	if(tree.kth(3)-tree.kth(2)==1&&tree.kth(2)-tree.kth(1)==1){
    		puts("TRUE");
    	}
    	else{
    		puts("FALSE");
    	}
    	return 0;
    }
    
    • 0
      @ 2023-7-10 16:24:07
      #include<iostream>
      using namespace std;
      int main()
      {
      	int a,b,c;
      	cin>>a>>b>>c;
      	if((a-b==1&&a-c==2)||(a-b==2&&a-c==1)||(b-a==1&&b-c==2)||(b-a==2&&b-c==1)||(c-a==1&&c-b==2)||(c-a==2&&c-b==1))
      	    cout<<"TRUE";
      	else cout<<"FALSE";	 
      	return 0;
      }
      
      • -1
        @ 2022-11-10 21:00:26
        #include<bits/stdc++.h>
        using namespace std;
        int main(){
        	int a,b,c,t;
        	cin>>a>>b>>c;
        	if(a>b){t=a;a=b;b=t;}
        if(a>c){t=a;a=c;c=t;}
        if(b>c){t=b;b=c;c=t;}
        if(b==a+1&&c==b+1)printf("TRUE");
        else printf("FALSE");
        return 0;
        }
        
        • -2
          @ 2023-7-10 16:22:50
          #include<iostream>
          using namespace std;
          int main()
          {
          	int x,y,z,n;
          	cin>>x>>y>>z>>n;
          	if(x>=y&&x>=z&&x>=n)
          	  cout<<x;
          	if(y>=z&&y>=x&&y>=n)
           	  cout<<y;
          	if(z>=x&&z>=y&&z>=n)
          	  cout<<z;
          	if(n>=x&&n>=y&&n>=z)
          	  cout<<n;
          	return 0;
          }
          
          • 1

          信息

          ID
          36
          时间
          1000ms
          内存
          16MiB
          难度
          6
          标签
          递交数
          374
          已通过
          118
          上传者