結果

問題 No.640 76本のトロンボーン
コンテスト
ユーザー 👑 tails
提出日時 2018-01-26 22:57:58
言語 C
(gcc 15.2.0)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 1,431 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,564 ms
コンパイル使用メモリ 26,904 KB
最終ジャッジ日時 2026-01-06 00:48:47
合計ジャッジ時間 2,426 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
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: 警告: 古いスタイルの関数定義です [-Wold-style-definition]
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’ があります [-Wreturn-mismatch]
    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: 警告: 古いスタイルの関数定義です [-Wold-style-definition]
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){
      |

ソースコード

diff #
raw source code

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