zoukankan      html  css  js  c++  java
  • 题解——Codeforces Round #508 (Div. 2) T2 (构造)

    按照题意构造集合即可

    注意无解情况的判断

    #include <cstdio>
    #include <algorithm>
    #include <cstring>
    #include <cmath>
    #include <vector>
    #include <map>
    using namespace std;
    int n,sum;
    int main(){
      scanf("%d",&n);
      if(n==1){
        printf("No
    ");
        return 0;
      }
      sum=(n+1)*n/2;
    //  printf("%d
    ",sum);
      for(int i=2;i<=sum;i++){
          for(int j=1;j<=sqrt(i);j++){
            if(i%j==0){
            if(j!=i/j){
            if(j!=1&&sum!=i){
                if((sum-i)%j==0){
                  vector<int> ax,bx;
                  int cnta=0,cntb=0;
                  int now=n;
                  for(int k=i;k>0;){
                    if(k>=now){
                      k-=now;
                      cnta++;
                      ax.push_back(now);
                      now--;
                    }
                  else{
                    cntb++;
                    bx.push_back(now);
                    now--;
                    }
                  }
                  while(now){
                    bx.push_back(now);
                    now--;
                    cntb++;
                  }
                  printf("Yes
    ");
                  printf("%d ",cnta);
                  for(int i=0;i<ax.size();i++)
                    printf("%d ",ax[i]);
                  printf("
    ");
                  printf("%d ",cntb);
                  for(int i=0;i<bx.size();i++)
                    printf("%d ",bx[i]);
                  printf("
    ");
                  return 0;
                }
              }
            if(i/j!=1&&sum!=i){
              if((sum-i)%(i/j)==0){
                vector<int> ax,bx;
                int cnta=0,cntb=0;
                  int now=n;
                  for(int k=i;k>0;){
                    if(k>=now){
                      k-=now;
                      cnta++;
                      ax.push_back(now);
                      now--;
                    }
                  else{
                    cntb++;
                    bx.push_back(now);
                    now--;
                    }
                  }
                  while(now){
                    bx.push_back(now);
                    now--;
                    cntb++;
                  }
                  printf("Yes
    ");
                  printf("%d ",cnta);
                  for(int i=0;i<ax.size();i++)
                    printf("%d ",ax[i]);
                  printf("
    ");
                  printf("%d ",cntb);
                  for(int i=0;i<bx.size();i++)
                    printf("%d ",bx[i]);
                  printf("
    ");
                  return 0;
                }
              }
            }
          else{
            if(j!=1&&i!=sum)
              if((sum-i)%j==0){
                vector<int> ax,bx;
                int cnta=0,cntb=0;
                  int now=n;
                  for(int k=i;k>0;){
                    if(k>=now){
                      k-=now;
                      cnta++;
                      ax.push_back(now);
                      now--;
                    }
                  else{
                    cntb++;
                    bx.push_back(now);
                    now--;
                    }
                  }
                while(now){
                  bx.push_back(now);
                  now--;
                  cntb++;
                }
                printf("Yes
    ");
                printf("%d ",cnta);
                for(int i=0;i<ax.size();i++)
                  printf("%d ",ax[i]);
                printf("
    ");
                printf("%d ",cntb);
                for(int i=0;i<bx.size();i++)
                  printf("%d ",bx[i]);
                printf("
    ");
                return 0;
              }
            }
          }
        }
      }
      printf("No
    ");
      return 0;
    }
  • 相关阅读:
    [IOI1998] Pictures
    【C++】位操作(3)-获取某位的值
    PAT A 1013. Battle Over Cities (25)【并查集】
    hihoCoder 1391 Countries【预处理+排序+优先队列】2016北京网络赛
    PAT A 1014. Waiting in Line (30)【队列模拟】
    codeforces Round#379 div.2
    PAT A 1004. Counting Leaves (30)【vector+dfs】
    POJ 1163:The Triangle
    LeetCode39/40/22/77/17/401/78/51/46/47/79 11道回溯题(Backtracking)
    BZOJ 3680 吊打XXX
  • 原文地址:https://www.cnblogs.com/dreagonm/p/9602507.html
Copyright © 2011-2022 走看看