日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內(nèi)最全IT社區(qū)平臺 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當(dāng)前位置:首頁 > 互聯(lián)網(wǎng) > Codeforces Round #263 (Div. 1) A B C

Codeforces Round #263 (Div. 1) A B C

來源:程序員人生   發(fā)布時間:2014-09-29 08:00:01 閱讀次數(shù):2326次

Codeforces Round #263 (Div. 1)

A:貪心,排個序,然后從后往前掃一遍,計算后綴和,之后在從左往右掃一遍計算答案

B:樹形DP,0表示沒有1,1表示有1,0遇到0必然合并,0遇到1也必然合并,1遇到0必然合并,1遇到1,必然切斷,按照這樣去轉(zhuǎn)移即可

C:樹狀數(shù)組,再利用啟發(fā)式合并,開一個l,r記錄當(dāng)前被子左右下標,和一個flip表示是否翻轉(zhuǎn)

代碼:

A:

#include <cstdio> #include <cstring> #include <cmath> #include <cstdlib> #include <algorithm> using namespace std; typedef long long ll; const int N = 300005; int n; ll a[N], sum[N]; int main() { scanf("%d", &n);ll ans = 0; for (int i = 0; i < n; i++) { scanf("%lld", &a[i]); ans += a[i]; } sort(a, a + n); for (int i = n - 1; i >= 0; i--) sum[i] = a[i] + sum[i + 1]; for (int i = 0; i < n - 1; i++) { ans += sum[i]; } printf("%lld ", ans); //system("pause"); return 0; }

B:

#include <cstdio> #include <cstring> #include <vector> #include <cstdlib> using namespace std; const int N = 100005; typedef long long ll; const ll MOD = 1000000007; int n, node[N]; vector<int> g[N]; ll dp[N][2]; ll pow_mod(ll x, ll k) { ll ans = 1; while (k) { if (k&1) ans = ans * x % MOD; x = x * x % MOD; k >>= 1; } return ans; } ll inv(ll x) { return pow_mod(x, MOD - 2); } void init() { scanf("%d", &n); int u; for (int i = 1; i < n; i++) { scanf("%d", &u); g[u].push_back(i); } for (int i = 0; i < n; i++) scanf("%d", &node[i]); } void dfs(int u) { if (g[u].size() == 0) { dp[u][node[u]] = 1; return; } for (int i = 0; i < g[u].size(); i++) dfs(g[u][i]); dp[u][0] = dp[u][1] = 1; if (node[u]) { dp[u][0] = 0; for (int i = 0; i < g[u].size(); i++) { int v = g[u][i]; dp[u][1] = dp[u][1] * (dp[v][0] + dp[v][1]) % MOD; } } else { ll cnt = 0; ll mul = 1; for (int i = 0; i < g[u].size(); i++) { int v = g[u][i]; dp[u][0] = dp[u][0] * (dp[v][0] + dp[v][1]) % MOD; mul = mul * (dp[v][0] + dp[v][1]) % MOD; } dp[u][1] = 0; for (int i = 0; i < g[u].size(); i++){ int v = g[u][i]; dp[u][1] = (dp[u][1] + mul * inv((dp[v][0] + dp[v][1]) % MOD) % MOD * dp[v][1]) % MOD; } } } int main() { init(); dfs(0); printf("%lld ", dp[0][1] % MOD); //system("pause"); return 0; }

C:

#include <cstdio> #include <cstring> #include <algorithm> using namespace std; #define lowbit(x) (x&(-x)) const int N = 100005; int n, q, bit[N]; void add(int x, int v) { while (x < N) { bit[x] += v; x += lowbit(x); } } int get(int x) { int ans = 0; while (x) { ans += bit[x]; x -= lowbit(x); } return ans; } int main() { scanf("%d%d", &n, &q); for (int i = 1; i <= n; i++) add(i, 1); int tp, a, b; int l = 1, r = n, flip = 0; while (q--) { scanf("%d%d", &tp, &a); if (tp == 1) { int tl = l, tr = r; if (a <= (r - l + 1) / 2) { if (flip) { for (int i = a; i >= 1; i--) { add(r - 2 * i + 1, get(tr - a + i) - get(tr - a + i - 1)); r--; } } else { for (int i = a; i >= 1; i--) { add(l + 2 * i - 1, get(tl + a - i) - get(tl + a - i - 1)); l++; } } } else { a = r - a - l + 1; if (!flip) { for (int i = a; i >= 1; i--) { add(r - 2 * i + 1, get(tr - a + i) - get(tr - a + i - 1)); r--; } } else { for (int i = a; i >= 1; i--) { add(l + 2 * i - 1, get(tl + a - i) - get(tl + a - i - 1)); l++; } } flip ^= 1; } } else { scanf("%d", &b); if (flip) { a = r - a; b = r - b; swap(a, b); } else { a += l - 1; b += l - 1; } printf("%d ", get(b) - get(a)); } } return 0; }


生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對您的學(xué)習(xí)有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關(guān)閉
程序員人生
主站蜘蛛池模板: heyzo久久 | 欧美一级片 | av免费网站在线观看 | 成人在线视频网 | 国产做爰免费视频观看 | 亚洲h | 色一情一区二 | 亚洲福利在线观看 | 中文字幕在线日韩 | 最新中文字幕在线观看 | 欧美日韩三级在线 | 亚洲国产成人91精品 | 国产一级片在线 | 午夜视频黄色 | 欧美日韩一区二区三区视频 | 免费av不卡 | 亚洲乱码一区二区三区三上悠亚 | 国产精品区二区三区日本 | 日韩av成人网| 免费看成年人视频在线观看 | 精品国产综合区久久久久久 | 免费欧美一级片 | 亚洲成人精品一区二区 | 久久三级网 | 国产经典一区二区三区 | 欧美日韩国产一区二区在线观看 | 日韩免费观看 | 成人精品久久久 | 日韩和欧美一区二区 | 成人区精品一区二区婷婷 | 久久成人综合 | 亚洲一区二区免费 | 男人操女人免费视频 | 久久蜜桃| 亚洲一区 中文字幕 | 亚洲一区在线观看视频 | 精品福利在线观看 | 久久精品福利视频 | 成人免费大片黄在线播放 | 91精品国产综合久久国产大片 | 成人a网|