結果

問題 No.326 あみだますたー
ユーザー akakimidoriakakimidori
提出日時 2017-06-08 23:33:35
言語 C90
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 859 bytes
コンパイル時間 345 ms
コンパイル使用メモリ 22,400 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-09-22 13:37:51
合計ジャッジ時間 3,648 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
6,812 KB
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 AC 1 ms
6,944 KB
testcase_06 AC 1 ms
6,940 KB
testcase_07 AC 1 ms
6,944 KB
testcase_08 AC 1 ms
6,944 KB
testcase_09 AC 2 ms
6,944 KB
testcase_10 AC 2 ms
6,940 KB
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
testcase_25 WA -
testcase_26 WA -
testcase_27 WA -
権限があれば一括ダウンロードができます
コンパイルメッセージ
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:27:5: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   27 |     scanf("%d",plan+i);
      |     ^~~~~~~~~~~~~~~~~~

ソースコード

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++){
    scanf("%d",plan+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