码迷,mamicode.com
首页 > 其他好文 > 详细

C. Sequence Transformation

时间:2018-10-06 16:40:02      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:sequence   for   最大   false   去掉   i++   clu   namespace   奇数   

链接

[http://codeforces.com/contest/1059/problem/C]

题意

给你一个n,有个序列有n个元素分别时1 ~ n,每次去掉一个元素输出剩下元素的GCD,使得最后的排列字典序最大

分析

显然第一个是1,有一点就是相邻的奇偶数必互质gcd==1,所有第二部就是一个接一个地去掉所有的奇数,
后面就剩下12,22....x2<=n,同理相邻的偶数gcd必是2,相差4的偶数gcd必是4,以此类推
但有个情况就是剩下3个数的时候,比如x,2
x,3x,怎么删除某个数都不能使gcd为2x,这时最大的字典序只能是x,x,3*x;
看代码就知道了

代码

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,base,i;
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    cin>>n;
        base=1;
        while(n){
            if(n==3)
            {
                cout<<base<<‘ ‘<<base<<‘ ‘<<3*base<<endl;
                break;
             } 
             for(i=1;i<=n/2+n%2;i++) cout<<base<<‘ ‘;
             n/=2;
             base*=2; 
                    }
    return 0;
}

C. Sequence Transformation

标签:sequence   for   最大   false   去掉   i++   clu   namespace   奇数   

原文地址:https://www.cnblogs.com/mch5201314/p/9747450.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!