結果
問題 | No.366 ロボットソート |
ユーザー | albicilla |
提出日時 | 2016-04-29 23:33:37 |
言語 | C++11 (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 3 ms / 2,000 ms |
コード長 | 531 bytes |
コンパイル時間 | 662 ms |
コンパイル使用メモリ | 58,840 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-12-29 17:43:57 |
合計ジャッジ時間 | 1,588 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 23 |
ソースコード
#include <iostream> #include <algorithm> using namespace std; int a[100000+10],b[100000+10],n,k,sw; int robotsort(int a[],int n,int k) { int sw=0; bool flag=1; for(int i=0;flag;i++) { flag=0; for(int j=n-1;j-k>=i;j--) { if(a[j]<a[j-k]) { swap(a[j],a[j-k]); flag=1; sw++; } } } return sw; } int main() { cin>>n>>k; for(int i=0;i<n;i++) { cin>>a[i]; b[i]=a[i]; } sw=robotsort(a,n,k); sort(b,b+n); for(int i=0;i<n;i++)if(a[i]!=b[i]){cout<<-1<<endl;return 0;} cout<<sw<<endl; }