AOJ(会津オンラインジャッジ)を最近始めて勉強しています。
ITP1_3_C 二つの数の交換 の問題でうまくいきません。
入力は3000行以内で、整数x,yを用いて
x y と空白区切りの一行で与えられます。
それを
y x のように逆にして出力するだけです。
「0 0」と入力されたら終了します。
正解を判定するテストケースでは1000パターン以上の大量のテストケースをもとに判定されていましたが、結果を見る限り、入れ替わっているのと入れ替わっていないのとで半々ぐらいでした。それも前半の半分は入れ替わっているけど後半はダメ、のようにわかりやすいものではなく、ランダムに失敗と成功のパターンが存在しているようです。
コードは以下のとおりです。
C
1#include <stdio.h> 2 3int main(void) { 4 int a, b,i; 5 for (i = 0; i < 3000; i++) { 6 scanf("%d %d", &a, &b); 7 if (a == 0 && b == 0) break; 8 9 printf("%d %d\n", b, a); 10 11 } 12 13 14 15 return 0; 16} 17コード
他にもswap関数を自分で作ったりもしましたが、やはり失敗と成功が混在します。VisualStudioでテストする限り、入れ替わらなかった時はありませんでした。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/05/19 14:18