結果
| 問題 |
No.355 数当てゲーム(2)
|
| コンテスト | |
| ユーザー |
kapo
|
| 提出日時 | 2016-05-07 14:43:54 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
TLE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 1,270 bytes |
| コンパイル時間 | 158 ms |
| コンパイル使用メモリ | 24,448 KB |
| 実行使用メモリ | 40,416 KB |
| 最終ジャッジ日時 | 2024-07-16 23:41:14 |
| 合計ジャッジ時間 | 6,632 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | TLE * 1 -- * 51 |
コンパイルメッセージ
main.cpp: In function ‘void perm(int)’:
main.cpp:12:30: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
12 | scanf("%d %d", &x, &y);
| ~~~~~^~~~~~~~~~~~~~~~~
main.cpp: In function ‘int main()’:
main.cpp:36:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
36 | scanf("%d %d", &x, &y);
| ~~~~~^~~~~~~~~~~~~~~~~
main.cpp:50:30: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
50 | scanf("%d %d", &x, &y);
| ~~~~~^~~~~~~~~~~~~~~~~
ソースコード
#include <stdio.h>
int b[4], p[4], p2[4], used[4], f=0;
void perm( int node)
{
if( node == 4 ) {
if( !f ) {
int i, x, y;
printf("%d %d %d %d\n", b[ p[0] ], b[ p[1] ], b[ p[2] ], b[ p[3] ]);
fflush(stdout);
scanf("%d %d", &x, &y);
if( x == 4 ) f = 1;
}
} else {
int i;
for( i = 0; i < 4; i++) {
if( !used[i] ) {
used[i] = 1;
p[node] = i;
perm(node+1);
used[i] = 0;
}
}
}
}
int main(void)
{
int i, j, k, a[4]={9,0,1,2}, x, y, xy=0, bxy=0, bcnt=0;
while( bcnt != 4) {
printf("%d %d %d %d\n", a[0], a[1], a[2], a[3]);
fflush(stdout);
scanf("%d %d", &x, &y);
xy = x+y;
for( j = 0; j < bcnt; j++) {
for( k = 0; k < 4; k++) if( a[k] == b[j] ) xy--;
}
int cnt = 0, s[10]={};
while( cnt < 10 ) {
for( i = 0; i < 4; i++) {
a[i] = (cnt+i) % 10;
}
printf("%d %d %d %d\n", a[0], a[1], a[2], a[3]);
fflush(stdout);
scanf("%d %d", &x, &y);
bxy = xy;
xy = x+y;
for( j = 0; j < bcnt; j++) {
for( k = 0; k < 4; k++) if( a[k] == b[j] ) xy--;
}
if( xy > bxy ) {
s[ (cnt+3) % 10] = 1;
} else if( xy < bxy ) {
s[ (cnt+9) % 10] = 1;
}
cnt++;
}
for( i = 0; i < 10; i++) {
if( s[i] ) {
b[bcnt] = i;
bcnt++;
}
}
}
perm(0);
return 0;
}
kapo