扯谈
对于排序,我自认为已经很熟练了(WHAT???如此自恋???)
这句话我写了一千万遍了吧
正文
放一张动态演示:
插入排序是一种很慢的排序:
时间复杂度:
空间复杂度:
思路:
在待排序的元素中,假设前n-1个元素已有序,现将第n个元素插入到前面已经排好的序列中,使得前n个元素有序。按照此法对所有元素进行插入,直到整个序列有序。
但我们并不能确定待排元素中究竟哪一部分是有序的,所以我们一开始只能认为第一个元素是有序的,依次将其后面的元素插入到这个有序序列中来,直到整个序列有序为止。
代码
#include<iostream>
using namespace std;
#define int long long
int a[1000005];
signed main() {
int n;
cin>>n;
if(n%2==1){
return cout<<"-1",0;
}
else{
a[1]=2;
for(int i=2;i<=30;i++){
a[i]=a[i-1]*2;
}
for(int i=30;i>=1;i--){
if(a[i]<=n){
n-=a[i];
cout<<a[i]<<" ";
}
if(n==0){
return 0;
}
}
}
return 0;
}