結果
| 問題 |
No.43 野球の試合
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-10-09 23:06:32 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 756 bytes |
| コンパイル時間 | 670 ms |
| コンパイル使用メモリ | 68,080 KB |
| 実行使用メモリ | 8,448 KB |
| 最終ジャッジ日時 | 2024-11-17 07:08:18 |
| 合計ジャッジ時間 | 7,996 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 6 TLE * 1 |
コンパイルメッセージ
main.cpp:42:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
42 | main()
| ^~~~
main.cpp: In function 'int dfs(int)':
main.cpp:41:1: warning: control reaches end of non-void function [-Wreturn-type]
41 | }
| ^
ソースコード
#include<iostream>
#include<algorithm>
using namespace std;
string s[7];int n;
int dfs(int t)
{
if(t)
{
int ret=1e9;
for(int i=0;i<n;i++)
{
for(int j=i;j<n;j++)
{
if(s[i][j]=='-')
{
s[i][j]='o';s[j][i]='x';ret=min(ret,dfs(t-1));
s[i][j]='x';s[j][i]='o';ret=min(ret,dfs(t-1));
s[i][j]=s[j][i]='-';
}
}
}
return ret;
}
else
{
int c[7]={};
for(int i=0;i<n;i++)for(int j=0;j<n;j++)c[i]+=s[i][j]=='o';
int ret=0;
for(int i=n;i--;)
{
for(int j=0;j<n;j++)
{
if(c[j]==i){ret++;break;}
}
if(c[0]==i)
{
return ret;
}
}
}
}
main()
{
cin>>n;for(int i=0;i<n;i++)cin>>s[i];
int cnt=0;
for(int i=0;i<n;i++)
{
for(int j=i;j<n;j++)cnt+=s[i][j]=='-';
}
cout<<dfs(cnt)<<endl;
}