結果

問題 No.2871 Universal Serial Bus
ユーザー forest3
提出日時 2025-02-28 15:17:34
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 856 bytes
コンパイル時間 1,642 ms
コンパイル使用メモリ 164,920 KB
実行使用メモリ 8,232 KB
最終ジャッジ日時 2025-02-28 15:17:37
合計ジャッジ時間 2,777 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 18
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

#define rep(i, n) for( int i = 0; i < n; i++ )
using ll = long long;

int main() {
	int H, W;
	cin >> H >> W;
	vector<string> s(H), t(H); 
	rep(i, H) cin >> s[i];
	rep(i, H) cin >> t[i];

	int f = 0;
	rep(i, H) rep(j, W) {
		if(s[i][j] == t[i][j]) f = 1;
	}
	int g = 0;
	rep(i, H) rep(j, W) {
		int ii = H - 1 - i;
		int jj = W - 1 - j;
		if(s[ii][jj] == t[i][j]) g = 1;
	}
	if(f && g) cout << -1 << endl;
	else {
		double ans = 0;
		if(g) {
			rep(i, 20) {
				int n = i + 1;
				int dn = n / 2;
				ans += exp2(-(dn * dn - dn));
			}
		}
		else if(f) {
			rep(i, 20) {
				int n = i + 1;
				int dn = (n - 1) / 2;
				ans += exp2(-(dn * dn));
			}
		}
		else {
			rep(i, 20) {
				int n = i + 1;
				ans += exp2(-((n - 2) * (n - 1) / 2));
			}
		}
		cout << fixed << setprecision(12) << ans << endl;
	}
}


0