摘要:
持续upddate中,非按难度排序 一,基础算法 1,搜索 (深度优先搜索 广度优先搜索)[转自 夜深人静写算法] 2,分治 3,贪心 4,排序 5,高精度 二,动态规划(重要板块) 1,线性动态规划 2,单调队列优化动态规划 3,背包型动态规划 4,区间动态规划 5,树上动态规划 6,DAG上动态 阅读全文
摘要:
因为去年考原题了,所以再次开启了刷水之旅 #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> using namespace std; char s[150]; int cnt[150],appear; 阅读全文
摘要:
树形DP,注意答案是节点数,我一直以为是边数懵逼了半个小时 #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> #define maxn 300010 using namespace std; struc 阅读全文
摘要:
重在建模QwQ,要将题意转化为 枚举1的个数k,计算有多少个数含有k个1,(因为数位dp就是来做,有多少满足的数,且不关注数的大小) 最后加个快速幂就好 #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> 阅读全文
摘要:
注意此类要处理前导零的数位DP题,因为如果前面全是0,这一位可以填0和1。 #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> #include<cmath> using namespace std; i 阅读全文
摘要:
Description 求小于等于n的数中满足含有13且各位数字和mod13等于0的数的个数。(n<=1e9) 数位DP #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> using namespace 阅读全文
摘要:
因为距离为2,所以枚举中间点即可。 #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> #define maxn 200010 using namespace std; struct node { int 阅读全文
摘要:
刷水QwQ 纯模拟 #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> #define maxn 3000 using namespace std; int n,num_a,num_b,a[maxn],b 阅读全文
摘要:
树形DP.. 设dp[i]表示从i到以i为根的子树的最远距离就好 转移dp[i]=max(dp[i],dp[e]+edge[i].len); 最后在遍历加一下答案就好。 记得开long long #include<cstdio> #include<iostream> #include<cstring 阅读全文
摘要:
感觉方程推错了,But居然过了QwQ #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> #define maxn 500010 using namespace std; struct node { in 阅读全文