結果

問題 No.640 76本のトロンボーン
ユーザー tailstails
提出日時 2018-01-26 22:57:58
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 1 ms / 2,000 ms
コード長 1,431 bytes
コンパイル時間 591 ms
コンパイル使用メモリ 30,892 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-27 22:59:33
合計ジャッジ時間 1,425 ms
ジャッジサーバーID
(参考情報)
judge12 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,380 KB
testcase_01 AC 1 ms
4,380 KB
testcase_02 AC 1 ms
4,380 KB
testcase_03 AC 1 ms
4,380 KB
testcase_04 AC 0 ms
4,380 KB
testcase_05 AC 1 ms
4,376 KB
testcase_06 AC 1 ms
4,380 KB
testcase_07 AC 1 ms
4,380 KB
testcase_08 AC 0 ms
4,380 KB
testcase_09 AC 1 ms
4,376 KB
testcase_10 AC 0 ms
4,376 KB
testcase_11 AC 1 ms
4,380 KB
testcase_12 AC 1 ms
4,376 KB
testcase_13 AC 0 ms
4,380 KB
testcase_14 AC 0 ms
4,376 KB
testcase_15 AC 1 ms
4,380 KB
testcase_16 AC 1 ms
4,376 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c:1:1: 警告: データ定義が型または記憶域クラスを持っていません
    1 | n;r;
      | ^
main.c:1:1: 警告: 型がデフォルトの ‘int’ に ‘n’ の宣言内でなります [-Wimplicit-int]
main.c:1:3: 警告: データ定義が型または記憶域クラスを持っていません
    1 | n;r;
      |   ^
main.c:1:3: 警告: 型がデフォルトの ‘int’ に ‘r’ の宣言内でなります [-Wimplicit-int]
main.c:5:1: 警告: 戻り値の型をデフォルトの ‘int’ にします [-Wimplicit-int]
    5 | f(x,y,a){
      | ^
main.c: 関数 ‘f’ 内:
main.c:5:1: 警告: ‘x’ の型をデフォルトの ‘int’ にします [-Wimplicit-int]
main.c:5:1: 警告: ‘y’ の型をデフォルトの ‘int’ にします [-Wimplicit-int]
main.c:5:1: 警告: ‘a’ の型をデフォルトの ‘int’ にします [-Wimplicit-int]
main.c:8:25: 警告: 非 void を戻す関数内に値が無い ‘return’ があります
    8 |                         return;
      |                         ^~~~~~
main.c:5:1: 備考: ここで宣言されています
    5 | f(x,y,a){
      | ^
main.c: トップレベル:
main.c:33:1: 警告: 戻り値の型をデフォルトの ‘int’ にします [-Wimplicit-int]
   33 | g(x,y,a){
      | ^
main.c: 関数 ‘g’ 内:
main.c:33:1: 警告: ‘x’ の型をデフォルトの ‘int’ にします [-Wimplicit-int]
main.c:33:1: 警告: ‘y’ の型をデフォルトの ‘int’ にします [-Wimplicit-int]
main.c:33:1: 警告: ‘a’ の型をデフォルトの ‘int’ にします [-Wimplicit-int]
main.c: トップレベル:
main.c:50:1: 警告: 戻り値の型をデフォルトの ‘int’ にします [-Wimplicit-int]
   50 | h(i){
      | ^
main.c: 関数 ‘h’ 内:
main.c:50:1: 警告: ‘i’ の型をデフォルトの ‘int’ にします [-Wimplicit-int]
main.c:52:34: 警告: 非 void を戻す関数内に値が無い ‘return’ があります
   52

ソースコード

diff #

n;r;
char s[99][99];
char t[99][99];

f(x,y,a){
	for(x=0;x<n-1;++x){
		if(t[0][x]=='#'){
			return;
		}
	}
	a=1;
	for(x=0;x<n-1;++x){
		for(y=1;y<n;++y){
			if(t[y][x]=='#'){
				goto dame1;
			}
		}
		++a;
		dame1:;
	}
	if(t[0][n-1]!='#'||t[n-1][n-1]!='#'){
		for(y=1;y<n-1;++y){
			if(t[y][n-1]=='#'){
				goto dame2;
			}
		}
		++a;
		dame2:;
	}
	if(r<a) r=a;
}

g(x,y,a){
	a=0;
	for(x=0;x<n;++x){
		if(t[0][x]=='#'&&t[n-1][x]=='#'){
			goto dame;
		}
		for(y=1;y<n-1;++y){
			if(t[y][x]=='#'){
				goto dame;
			}
		}
		++a;
		dame:;
	}
	if(r<a) r=a;
}

h(i){
	for(i=0;i<n;++i){
		if(t[0][i]=='#') return;
		if(t[n-1][i]=='#') return;
		if(t[i][0]=='#') return;
		if(t[i][n-1]=='#') return;
	}
	if(r<4) r=4;
}

main(x,y){
	scanf("%d ",&n);
	for(y=0;y<n;++y){
		gets(s[y]);
	}
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[y][x];
		}
	}
	h();
	g();
	f();
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[y][n-1-x];
		}
	}
	h();
	f();
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[n-1-y][x];
		}
	}
	f();
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[n-1-y][n-1-x];
		}
	}
	f();
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[x][y];
		}
	}
	g();
	f();
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[x][n-1-y];
		}
	}
	f();
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[n-1-x][y];
		}
	}
	f();
	for(y=0;y<n;++y){
		for(x=0;x<n;++x){
			t[y][x]=s[n-1-x][n-1-y];
		}
	}
	f();
	printf("%d",r);
}
0