aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--21/open/balanced.cpp118
1 files changed, 118 insertions, 0 deletions
diff --git a/21/open/balanced.cpp b/21/open/balanced.cpp
new file mode 100644
index 0000000..02404a3
--- /dev/null
+++ b/21/open/balanced.cpp
@@ -0,0 +1,118 @@
+#include <bits/stdc++.h>
+#define f first
+#define s second
+using namespace std;
+using ll = long long;
+using ii = pair<int, int>;
+constexpr int MX = 155, MOD = 1e9+7;
+
+inline void add(int & x, int y) { x += y; if (x > MOD) x -= MOD; }
+
+string S[MX];
+
+struct fenwick_tree_2d {
+ int FT[MX][MX];
+ fenwick_tree_2d() { memset(FT, 0, sizeof FT); }
+ inline void update(int x, int y, int v) {
+ for (int i = x+1; i < MX; i += i&-i)
+ for (int j = y+1; j < MX; j += j&-j) add(FT[i][j], v);
+ }
+ inline int query(int x, int y) {
+ int ret = 0;
+ for (int i = x+1; i > 0; i -= i&-i)
+ for (int j = y+1; j > 0; j -= j&-j) add(ret, FT[i][j]);
+ return ret;
+ }
+ inline int query(int xl, int xr, int yl, int yr) {
+ int ret = query(xr, yr);
+ add(ret, MOD-query(xl-1, yr));
+ add(ret, MOD-query(xr, yl-1));
+ add(ret, query(xl-1, yl-1));
+ return ret;
+ }
+} DP[MX][4];
+
+int main() {
+ if (fopen("in", "r")) freopen("in", "r", stdin), freopen("out", "w", stdout);
+ cin.tie(0)->sync_with_stdio(0);
+
+ int N; cin >> N;
+ for (int i = 0; i < N; ++i) cin >> S[i];
+
+ int ans = 0;
+ for (int i = 0; i < N; ++i) {
+ for (int a = 0; a < N; ++a) {
+ for (int b = a; b < N; ++b) {
+ if (S[i][b] != 'G') break;
+
+ int sum = 1;
+
+ int d0bb = DP[i][0].query(b,b);
+ int d0a1b = DP[i][0].query(a-1,b);
+ int d0ba1 = DP[i][0].query(b,a-1);
+ int d0a1a1 = DP[i][0].query(a-1,a-1);
+ // DP[i][0] query(b,b)-query(a-1,b)-query(b,a-1)+query(a-1,a-1);
+ // add(sum, DP[i][0].query(a, b, a, b));
+ add(sum, d0bb), add(sum, MOD-d0a1b), add(sum, MOD-d0ba1), add(sum, d0a1a1);
+ DP[i+1][0].update(a, b, sum);
+ add(ans, sum);
+
+ int d1bn1 = DP[i][1].query(b, N-1);
+ int d1a1n1 = DP[i][1].query(a-1, N-1);
+ int d1bb1 = DP[i][1].query(b,b-1);
+ int d1a1b1 = DP[i][1].query(a-1,b-1);
+ int d0bn1 = DP[i][0].query(b,N-1);
+ int d0a1n1 = DP[i][0].query(a-1,N-1);
+ // DP[i][1] query(b, N-1)-query(a-1,N-1)-query(b,b-1)+query(a-1, b-1)
+ // DP[i][0] query(b, N-1)-query(a-1, N-1)-query(b,b)+query(a-1, b)
+ // sum = DP[i][1].query(a, b, b, N-1);
+ sum = 0; add(sum, d1bn1), add(sum, MOD-d1a1n1), add(sum, MOD-d1bb1), add(sum, d1a1b1);
+ // add(sum, DP[i][0].query(a, b, b+1, N-1));
+ add(sum, d0bn1), add(sum, MOD-d0a1n1), add(sum, MOD-d0bb), add(sum, d0a1b);
+ DP[i+1][1].update(a, b, sum);
+ add(ans, sum);
+
+ int d2ab = DP[i][2].query(a, b);
+ //int d21b = 0; //DP[i][2].query(-1, b);
+ int d2aa1 = DP[i][2].query(a, a-1);
+ //int d21a1 = 0; //DP[i][2].query(-1, a-1);
+ //int d01b = 0; //DP[i][0].query(-1, b);
+ //int d01a1 = 0; //DP[i][0].query(-1, a-1);
+ // DP[i][2] query(a,b)-query(-1,b)-query(a, a-1)+query(-1, a-1)
+ // DP[i][0] query(a-1, b)-query(-1,b)-query(a-1,a-1)+query(-1,a-1)
+ // sum = DP[i][2].query(0, a, a, b);
+ sum = 0; add(sum, d2ab); //add(sum, MOD-d21b),
+ add(sum, MOD-d2aa1);//, add(sum, d21a1);
+ // add(sum, DP[i][0].query(0, a-1, a, b));
+ add(sum, d0a1b);//, add(sum, MOD-d01b),
+ add(sum, MOD-d0a1a1);//, add(sum, d01a1);
+ DP[i+1][2].update(a, b, sum);
+ add(ans, sum);
+
+ // int d01n1 = 0;//DP[i][0].query(-1,N-1);
+ // int d11n1 = 0;//DP[i][1].query(-1, N-1);
+ // int d11b1 = 0;//DP[i][1].query(-1, b-1);
+ int d2an1 = DP[i][2].query(a, N-1);
+ // int d21n1 = 0;//DP[i][2].query(-1, N-1);
+ // DP[i][3] query(a, N-1)-query(-1,N-1)-query(a,b-1)+query(-1, b-1)
+ // DP[i][0] query(a-1, N-1)-query(-1,N-1)-query(a-1,b)+query(-1, b)
+ // DP[i][1] query(a-1, N-1)-query(-1,N-1)-query(a-1,b-1)+query(-1, b-1)
+ // DP[i][2] query(a, N-1)-query(-1,N-1)-query(a,b)+query(-1, b)
+ sum = DP[i][3].query(a, N-1); add(sum, MOD-DP[i][3].query(a,b-1));
+ // add(sum, DP[i][0].query(0, a-1, b+1, N-1));
+ add(sum, d0a1n1);//, add(sum, MOD-d01n1),
+ add(sum, MOD-d0a1b);//, add(sum, d01b);
+ // add(sum, DP[i][1].query(0, a-1, b, N-1));
+ add(sum, d1a1n1);//, add(sum, MOD-d11n1),
+ add(sum, MOD-d1a1b1);//, add(sum, d11b1);
+ // add(sum, DP[i][2].query(0, a, b+1, N-1));
+ add(sum, d2an1);
+ //add(sum, MOD-d21n1),
+ add(sum, MOD-d2ab);//, add(sum, d21b);
+ DP[i+1][3].update(a, b, sum);
+ add(ans, sum);
+ }
+ }
+ }
+ cout << ans%MOD;
+}