提交时间:2024-03-09 10:05:16

运行 ID: 136518

#include<bits/stdc++.h> using namespace std; int a[1000005]; int main(){ int n; cin>>n; for(int i=1;i<=n;i++)cin>>a[i]; for(int d = n/2;d>=1;d/=2) for(int i=d;i<=n;i++){ if(a[i]<a[i-d]){ int t = a[i]; int j = i-d; for(; j>=1 && a[j]>t ;j-=d){ a[j+d] = a[j]; } a[j+d] = t; } } for(int i=1;i<=n;i++)printf("%d ",a[i]); return 0; }