結果

問題 No.326 あみだますたー
ユーザー akakimidoriakakimidori
提出日時 2017-06-08 23:50:58
言語 C90
(gcc 11.4.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 881 bytes
コンパイル時間 234 ms
コンパイル使用メモリ 22,844 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-23 19:55:57
合計ジャッジ時間 1,414 ms
ジャッジサーバーID
(参考情報)
judge14 / judge11
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,348 KB
testcase_01 AC 0 ms
4,348 KB
testcase_02 AC 0 ms
4,348 KB
testcase_03 AC 1 ms
4,348 KB
testcase_04 AC 1 ms
4,348 KB
testcase_05 AC 0 ms
4,348 KB
testcase_06 AC 1 ms
4,348 KB
testcase_07 AC 0 ms
4,348 KB
testcase_08 AC 1 ms
4,348 KB
testcase_09 AC 2 ms
4,348 KB
testcase_10 AC 2 ms
4,348 KB
testcase_11 AC 0 ms
4,348 KB
testcase_12 AC 1 ms
4,348 KB
testcase_13 AC 1 ms
4,348 KB
testcase_14 AC 1 ms
4,348 KB
testcase_15 AC 1 ms
4,348 KB
testcase_16 AC 1 ms
4,348 KB
testcase_17 AC 1 ms
4,348 KB
testcase_18 AC 1 ms
4,348 KB
testcase_19 AC 1 ms
4,348 KB
testcase_20 AC 0 ms
4,348 KB
testcase_21 AC 1 ms
4,348 KB
testcase_22 AC 1 ms
4,348 KB
testcase_23 AC 1 ms
4,348 KB
testcase_24 AC 2 ms
4,348 KB
testcase_25 AC 1 ms
4,348 KB
testcase_26 AC 0 ms
4,348 KB
testcase_27 AC 1 ms
4,348 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function ‘run’:
main.c:13:3: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   13 |   scanf("%d%d",&n,&k);
      |   ^~~~~~~~~~~~~~~~~~~
main.c:21:5: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   21 |     scanf("%d%*d",&x);
      |     ^~~~~~~~~~~~~~~~~
main.c:28:5: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   28 |     scanf("%d",&x);
      |     ^~~~~~~~~~~~~~

ソースコード

diff #

#include<stdio.h>
#include<stdlib.h>

void swap(int *a,int i,int j){
  int t=a[i];
  a[i]=a[j];
  a[j]=t;
  return;
}

void run(void){
  int n,k;
  scanf("%d%d",&n,&k);
  int *state=(int *)malloc(sizeof(int)*(n+1));
  int i;
  for(i=0;i<=n;i++){
    state[i]=i;
  }
  for(i=0;i<k;i++){
    int x;
    scanf("%d%*d",&x);
    swap(state,x,x+1);
  }

  int *plan=(int *)malloc(sizeof(int)*(n+1));
  for(i=1;i<=n;i++){
    int x;
    scanf("%d",&x);
    plan[x]=i;
  }

  int *ans=(int *)malloc(sizeof(int)*6000);
  int len=0;
  for(i=1;i<n;i++){
    if(plan[i]==state[i]) 
      continue;

    int j;
    for(j=i;state[j+1]!=plan[i];j++);

    while(j>=i){
      swap(state,j,j+1);
      ans[len++]=j--;
    }
  }

  printf("%d\n",len);
  for(i=0;i<len;i++){
    printf("%d %d\n",ans[i],ans[i]+1);
  }

  free(state);
  free(plan);
  return;
}

int main(void){
  run();
  return 0;
}
0