Wannafly挑战赛14

A.角三棱锥

枚举推式子

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 typedef long long LL;
 4 LL gcd(LL a, LL b){
 5     return a % b ? gcd(b, a % b) : b;
 6 }
 7 int main(){
 8     int T;
 9     scanf("%d", &T);
10     while(T--) {
11         LL K, M, six = 6;
12         cin >> K >> M;
13         LL a = K + 1, b = K + 2, c = K + 3;
14         LL g = gcd(a, six);
15         a /= g, six /= g;
16         g = gcd(b, six);
17         b /= g, six /= g;
18         g = gcd(c, six);
19         c /= g, six /= g;
20         LL ans = a * b % M * c % M;
21         cout << ans << endl;
22     }
23     return 0;
24 }

Aguin

B.缀查询

子树修改子树询问转路径标记

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 1e6 + 10;
 4 typedef long long LL;
 5
 6 int node;
 7 LL val[maxn], num[maxn], del[maxn];
 8 LL sum[maxn], tot[maxn];
 9 map<char, int> G[maxn];
10 void insert(string s, LL v){
11     int p = 0;
12     for(int i = 0; i < s.length(); ++i){
13         if(G[p].find(s[i]) == G[p].end()) G[p][s[i]] = ++node;
14         p = G[p][s[i]];
15         v -= del[p];
16         sum[p] += v;
17         tot[p]++;
18     }
19     val[p] += v;
20     num[p]++;
21 }
22 void modify(string s, LL v) {
23     int p = 0;
24     for (int i = 0; i < s.length(); ++i) {
25         if (G[p].find(s[i]) == G[p].end()) G[p][s[i]] = ++node;
26         p = G[p][s[i]];
27     }
28     del[p] += v;
29     LL tmp = tot[p];
30     p = 0;
31     for (int i = 0; i < s.length(); ++i) {
32         if (G[p].find(s[i]) == G[p].end()) G[p][s[i]] = ++node;
33         p = G[p][s[i]];
34         if(i != s.length() - 1) sum[p] += tmp * v;
35     }
36 }
37 LL Q1(string s) {
38     int p = 0;
39     LL tmp = 0;
40     for (int i = 0; i < s.length(); ++i) {
41         if (G[p].find(s[i]) == G[p].end()) G[p][s[i]] = ++node;
42         p = G[p][s[i]];
43         tmp += del[p];
44     }
45     return val[p] + tmp * num[p];
46 }
47 LL Q2(string s) {
48     int p = 0;
49     LL tmp = 0;
50     for (int i = 0; i < s.length(); ++i) {
51         if (G[p].find(s[i]) == G[p].end()) G[p][s[i]] = ++node;
52         p = G[p][s[i]];
53         tmp += del[p];
54     }
55     return sum[p] + tmp * tot[p];
56 }
57
58 char s[maxn];
59 int main(){
60     int N;
61     scanf("%d", &N);
62     for(int i = 1; i <= N; ++i){
63         int o, a, b;
64         scanf("%d", &o);
65         if(o == 1){
66             scanf("%s %d", s, &a);
67             insert(string(s), a);
68         }
69         else if(o == 2){
70             scanf("%s %d", s, &a);
71             modify(string(s), a);
72         }
73         else if(o == 3){
74             scanf("%s", s);
75             printf("%lld\n", Q1(string(s)));
76         }
77         else{
78             scanf("%s", s);
79             printf("%lld\n", Q2(string(s)));
80         }
81     }
82     return 0;
83 }

Aguin

C.达性

缩点

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 1e5 + 10;
 4
 5 // BCC
 6 set<int> SE[maxn], ans;
 7 set<int> :: iterator it;
 8 stack<int> S;
 9 vector<int> G[maxn];
10 int dfs_clock, dfn[maxn], low[maxn];
11 int bcc_cnt, bccno[maxn];
12 void dfs(int u, int fa)
13 {
14     dfn[u] = low[u] = ++dfs_clock;
15     S.push(u);
16     for(int i = 0; i < G[u].size(); ++i)
17     {
18         int v = G[u][i];
19         if(!dfn[v])
20         {
21             dfs(v, u);
22             low[u] = min(low[u], low[v]);
23         }
24         else if(!bccno[v]) low[u] = min(low[u], dfn[v]);
25     }
26
27     if(low[u] == dfn[u])
28     {
29         bcc_cnt++;
30         while(1)
31         {
32             int x = S.top(); S.pop();
33             bccno[x] = bcc_cnt;
34             SE[bcc_cnt].insert(x);
35             if(x == u) break;
36         }
37     }
38 }
39
40 void find_bcc(int n)
41 {
42     memset(dfn, 0, sizeof(dfn));
43     memset(bccno, 0, sizeof(bccno));
44     dfs_clock = bcc_cnt = 0;
45     for(int i = 1; i <= n; i++) if(!dfn[i]) dfs(i, 0);
46 }
47
48 int deg[maxn];
49 int main(){
50     int n, m;
51     scanf("%d %d", &n, &m);
52     for(int i = 1; i <= m; ++i){
53         int u, v;
54         scanf("%d %d", &u, &v);
55         G[u].push_back(v);
56     }
57     find_bcc(n);
58     for(int i = 1; i <= n; ++i){
59         for(int j = 0; j < G[i].size(); ++j)
60             if(bccno[i] != bccno[G[i][j]]) deg[bccno[G[i][j]]]++;
61     }
62     for(int i = 1; i <= bcc_cnt; ++i){
63         if(deg[i] == 0) ans.insert(*SE[i].begin());
64     }
65     printf("%d\n", ans.size());
66     for(it = ans.begin(); it != ans.end(); it++){
67         if(it != ans.begin()) putchar(‘ ‘);
68         printf("%d", *it);
69     }
70     puts("");
71     return 0;
72 }

Aguin

D.codeJan和树

启发式合并

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 1e5 + 10;
 4 typedef long long LL;
 5 typedef pair<int, int> pii;
 6 vector<pii> G[maxn];
 7 int n, m;
 8
 9 int sz[maxn];
10 LL bt[maxn];
11 void dfs(int x, int f){
12     bt[x] = 0;
13     sz[x] = 1;
14     for(int i = 0; i < G[x].size(); ++i){
15         int to = G[x][i].first, d = G[x][i].second;
16         if(to == f) continue;
17         dfs(to, x);
18         bt[x] += bt[to] + d * sz[to];
19         sz[x] += sz[to];
20     }
21 }
22
23 LL ans;
24 int id[maxn];
25 map<LL, int> S[maxn];
26 map<LL, int> :: iterator it;
27 void add(int x, int f, int y){
28     S[y][bt[x]] = 1;
29     for(int i = 0; i < G[x].size(); ++i){
30         int to = G[x][i].first;
31         if(to == f) continue;
32         add(to, x, y);
33     }
34 }
35 void dfs1(int x, int f){
36     id[x] = x;
37     int M = 0, ms = 0;
38     for(int i = 0; i < G[x].size(); ++i){
39         int to = G[x][i].first;
40         if(to == f) continue;
41         dfs1(to, x);
42         if(sz[to] > M) M = sz[to], ms = to;
43     }
44     if(ms) id[x] = id[ms];
45     for(int i = 0; i < G[x].size(); ++i){
46         int to = G[x][i].first;
47         if(to == f || to == ms) continue;
48         add(to, x, id[x]);
49     }
50     it = S[id[x]].lower_bound(bt[x] - m);
51     if(it != S[id[x]].end()) ans = max(ans, bt[x] - (*it).first);
52     S[id[x]][bt[x]] = 1;
53 }
54
55 int main(){
56     int T;
57     scanf("%d", &T);
58     while(T--){
59         scanf("%d %d", &n, &m);
60         for(int i = 1; i <= n; ++i) G[i].clear(), S[i].clear();
61         for(int i = 1; i < n; ++i){
62             int u, v, d;
63             scanf("%d %d %d", &u, &v, &d);
64             G[u].push_back(pii(v, d));
65             G[v].push_back(pii(u, d));
66         }
67         ans = -1;
68         dfs(1, 0);
69         dfs1(1, 0);
70         printf("%lld\n", ans);
71     }
72     return 0;
73 }

Aguin

E.效位置

倒着并茶几

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 1e5 + 10;
 4 int a[maxn], b[maxn], ans[maxn];
 5 int base[maxn][33], vis[maxn];
 6
 7 int fa[maxn];
 8 int Find(int x){
 9     return fa[x] == x ? x : fa[x] = Find(fa[x]);
10 }
11 void Union(int x, int y){
12     x = Find(x), y = Find(y);
13     if(x == y) return;
14     for(int i = 29; i >= 0; i--){
15         if(!base[x][i]) continue;
16         for(int j = 29; j >= 0; j--){
17             if((1 << j) & base[x][i]){
18                 if(base[y][j]) base[x][i] ^= base[y][j];
19                 else {
20                     base[y][j] = base[x][i];
21                     break;
22                 }
23             }
24         }
25     }
26     fa[x] = y;
27 }
28
29 int main(){
30     int N, M = 0;
31     scanf("%d", &N);
32     for(int i = 1; i <= N; ++i) fa[i] = i;
33     for(int i = 1; i <= N; ++i) scanf("%d", a + i);
34     for(int i = 1; i <= N; ++i) scanf("%d", b + i);
35     for(int i = N; i >= 1; --i){
36         int x = a[b[i]], y = 0;
37         for(int j = 29; j >= 0; --j){
38             if((1 << j) & x){
39                 base[b[i]][j] = x;
40                 break;
41             }
42         }
43         vis[b[i]] = 1;
44         if(vis[b[i] - 1]) Union(b[i] - 1, b[i]);
45         if(vis[b[i] + 1]) Union(b[i] + 1, b[i]);
46         x = Find(b[i]);
47         for(int j = 29; j >= 0; --j){
48             if((1 << j) & y) continue;
49             y ^= base[x][j];
50         }
51         M = max(M, y);
52         ans[i] = M;
53     }
54     for(int i = 1; i <= N; ++i) printf("%d\n", ans[i]);
55     return 0;
56 }

Aguin

F.

原文地址:https://www.cnblogs.com/Aguin/p/8893861.html

时间: 2024-10-10 00:06:52

Wannafly挑战赛14的相关文章

Wannafly挑战赛14 F.细胞

题解:NTT.二项式定理 再逆FFT求出系数ans[i],本题即可解了 另:采用FFT的话,复数既不方便,误差也很大. 从FFT到NTT: 由费马小定理可知 gp-1%p=1    (p为质数) 所以利用这个性质来对应单位复数根乘方的周期性,即 代码: #include<iostream> using namespace std; typedef long long ll; const ll Mod=998244353; const ll G=3; ll kpow(ll a,ll k) { l

Wannafly挑战赛3

Wannafly挑战赛3 A    珂朵莉 B    遇见 水题 #include<bits/stdc++.h> using namespace std; #pragma comment(linker, "/STACK:102400000,102400000") #define rep(i,a,b) for (int i=a; i<=b; ++i) #define per(i,b,a) for (int i=b; i>=a; --i) #define mes(a

【Wannafly挑战赛4】F 线路规划 倍增+Kruskal+归并

[Wannafly挑战赛4]F 线路规划 题目描述 Q国的监察院是一个神秘的组织.这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人.监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只听从其上直接司的命令.其中1号成员是监察院的院长,这个庞然大物的主人.由于时代的进步,监察院议会决定升级组织的旧式通信器,安装最新的反侦测通信器.他们拿出了M组线路方案,其中第i组线路方案可以用一个四元组(x[i].y[i].k[i].w[i])描述,表示第x[i]号成员可以安装与y[i]号成员的直

牛客网 Wannafly挑战赛8 C-小C打比赛 (状压DP)

小C现在要参加一场wannafly挑战赛,一场挑战赛一共有n道题,一共有m分钟. 对于第i道题,小C解决它需要恰好j分钟的概率是pi,j. 小C每次会选择某一道没做完的题,然后把它解决(不能中途放弃),之后再决策下一道要做的题是哪道. 求小C在最优策略下,期望能做出几道题. 输入描述: 第一行两个正整数n,m接下来一共n行,每行有m个小数,第i行的第j个小数表示p i,j (这里假设不存在0分钟A题的dalao). 输出描述: 输出一个小数,表示期望能做出几道题,保留小数点后五位. 示例1 输入

Wannafly挑战赛11 D 白兔的字符串 Hash

Wannafly挑战赛11 D   白兔的字符串 白兔有一个字符串T.白云有若干个字符串S1,S2..Sn. 白兔想知道,对于白云的每一个字符串,它有多少个子串是和T循环同构的. 提示:对于一个字符串a,每次把a的第一个字符移动到最后一个,如果操作若干次后能够得到字符串b,则a和b循环同构. 所有字符都是小写英文字母 输入描述: 第一行一个字符串T(|T|<=10^6)第二行一个正整数n (n<=1000)接下来n行为S1~Sn (|S1|+|S2|+…+|Sn|<=10^7),max(

Wannafly挑战赛18

Wannafly挑战赛18 A. 序列 先考虑暴力,相邻两个树之间乘上给定的三种数,递推出下一个位置填什么,然后再check一下,最后一位是否为1即可.这样时间显然不行,但是给我们一种思路,就是中间的转换关系,确定唯一一个序列.现在的目标是让最后一位出现1,可以如果不管1,由-2和0.5取凑出1需要两个-2和两个0.5.那所有的转换中,就只要保证有若干组(-2,-2,0.5,0.5)存在,其他地方为1即可.具体公式见代码 #include <bits/stdc++.h> #define rep

Wannafly挑战赛19

Wannafly挑战赛19 A. 队列Q 需要支持把一个元素移到队首,把一个元素移到队尾,移到队首就直接放到队首前面那个位置,原位置标为0,队尾同理. #include <bits/stdc++.h> #define rep(i,a,b) for(int i=a;i<=b;++i) typedef long long ll; const int N = 30000200; using namespace std; int n,m; int q[N],hd,x,ed,P[N]; char

Wannafly挑战赛22游记

Wannafly挑战赛22游记 幸福的人都是相似的,不幸的人各有各的不幸. --题记 A-计数器 题目大意: 有一个计数器,计数器的初始值为\(0\),每次操作你可以把计数器的值加上\(a_1,a_2,\ldots,a_n\)中的任意一个整数,操作次数不限(可以为\(0\)次),问计数器的值对\(m\)取模后有几种可能. 思路: 由裴蜀定理易得,答案即为\(\frac m{\gcd(m,a_1,a_2,\ldots,a_n)}\). 源代码: #include<cstdio> #include

Wannafly挑战赛25游记

Wannafly挑战赛25游记 A - 因子 题目大意: 令\(x=n!(n\le10^{12})\),给定一大于\(1\)的正整数\(p(p\le10000)\)求一个\(k\)使得\(p^k|x\)并且\(p^{k+1}\not|x\)的因子. 思路: 枚举\(p\)的每一个质因数\(q\),求出它在\(n!\)出现次数\(/p\)中出现次数,取\(\min\)即可.对于一个质因数\(q\),在\(n!\)中出现的次数等于\(\sum_{i=1}^{\inf}\frac n{q^i}\).