河南省队选拔 HAOI2015 解题报告
其实省选在四天前就已经结束了,但由于题目难度略大我到今天上午才补完所有题目……(捂脸逃)考场上很幸运,打完了所有我会写的部分分,最后Round1的110分 + Round2的70分,勉强算是没有被联赛day2的文件夹坑太多。。。
目前网上比较容易找到的题解似乎只有ydc教主的这份:http://ydc.blog.uoj.ac/blog/336,不过对于我这种水平的人来说这份题解还不是很好理解,那么我再来稍微补充一点更基础的内容吧。。
A.T1
有一棵点数为N的树,树边有边权。给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并将其他的N-K个点染成白色。将所有点染色后,你会获得黑点两两之间的距离加上白点两两之间距离的和的收益。问收益最大值是多少。
其中$1 \leq N \leq 2000, 0 \leq K \leq N$。
分析.
从点和点的距离入手不太好分析……我在考场上想了一两个小时最后还是弃疗了,连暴力都没心情写,交了一份靠运气的贪心骗分。
其实呢……由于树上每一条边都是桥,我们可以从每一条边两端的黑白点数入手,也就是考虑每条边对答案造成的贡献。定义函数f(v, i)表示在v子树中,共将i个点染色后,能得到的“子树中所有点的父边的对答案的贡献之和”的最大值。这样每棵子树就成了一个可分割的子结构,就可以做树形背包了。
根据官方题解中给出的那种神奇的证明,这样做的时间复杂度是$O(N^2)$.
代码.
2 /**********************By Asm.Def-Wu Jiaxin*****************************/
3 /***********************************************************************/
4 #include
5 #include
6 #include
7 #include
8 #include
9 #include
using namespace std;
#define SetFile(x) ( freopen(#x".in", "r", stdin), freopen(#x".out", "w", stdout) );
#define UseFREAD
#ifdef UseFREAD
#define getc() *(file_ptr++)
#define FreadLenth 5000000
char CHARPOOL[FreadLenth], *file_ptr = CHARPOOL;
#else
#define getc() getchar()
#endif
#ifdef DEBUG
#include
timeb SysTp;
#endif
template<class T>inline void getd(T &x){
char ch = getc();bool neg = false;
while(!isdigit(ch) && ch != '-')ch = getc();
if(ch == '-')ch = getc(), neg = true;
x = ch - ';
- ' + ch;
if(neg)x = -x;
}
/***********************************************************************/
;
typedef long long LL;
#include
struct Edge{int to, w;};
vector adj[maxn];
LL f[maxn][maxn], S[maxn][maxn];
int N, K, size[maxn];
inline void UPD(LL &a, const LL &b){if(a < b)a = b;}
void dfs(int cur, int p, int w){
vector::iterator it;
int i, j, to;
size[cur] = ;
for(it = adj[cur].begin();it != adj[cur].end();++it)if((to = (*it).to) != p){
dfs(to, cur, (*it).w);
;--i);--j)
UPD(S[cur][i + j], S[cur][i] + f[to][j]);
size[cur] += size[to];
}
;--i)
f[cur][i] = S[cur][i] + (LL)w * (i * (K - i) + (N - K - size[cur] + i) * (size[cur] - i));
}
inline void work(){
getd(N), getd(K);
int i, a, b, c;
;i < N;++i){
getd(a), getd(b), getd(c);
adj[a].push_back((Edge){b, c});
adj[b].push_back((Edge){a, c});
}
dfs(, , );
printf(][K]);
}
int main(){
#ifdef DEBUG
freopen("test.txt", "r", stdin);ftime(&SysTp);
size_t Begin_sec = SysTp.time, Begin_mill = SysTp.millitm;
#elif !defined ONLINE_JUDGE
SetFile(haoi2015_t1);
#endif
#ifdef UseFREAD
fread(file_ptr, , FreadLenth, stdin);
#endif
work();
#ifdef DEBUG
ftime(&SysTp);
printf("\n%.3lf sec \n", (SysTp.time - Begin_sec) + (SysTp.millitm - Begin_mill) / 1000.0);
#endif
;
}
树形背包
B.T2
有一棵点数为N的树,以点1为根,且树点有边权。然后有M个操作,分为三种:
操作1 1 x a:把某个节点x的点权增加a。
操作2 2 x a:把某个节点x为根的子树中所有点的点权都增加a。
操作3 3 x:询问某个节点x到根的路径中所有点的点权和。
对于100%的数据,N,M<=100000,且所有输入数据的绝对值都不会超过10^6
分析.
其实我们这样来看……对于一次操作(2 u x),我们来考虑这次操作对u的某个后代v的贡献。不难看出,从u到v路径上的每个点的权值都被增加了x,这个操作对v的答案的增量$d_v = (dist(u, v) + 1) * x$ 。然而dist(u, v)这个东西似乎不太容易作为区间修改的增量。由于u是v的祖先,我们不妨把dist拆一下,那么$d_v = (dep_v - dep_u + 1) * x$,或者$d_v = dep_v * x - (dep_u - 1) * x$.(其中$dep_i$表示i点到根的距离)这时我们其实已经把这次操作的贡献拆成了一个关于点v的深度的一次函数,那么每次进行操作时只要分别修改两项的系数就可以了。
代码.
2 /******************************Designed By Asm.Def****************************/
3 /*****************************************************************************/
4 #include
5 #include
6 #include
7 #include
8 #include
9 #include
10 //#define FREAD
11 #ifdef FREAD
12 #define FREADLENTH 5000000
13 char *fread_ptr = (char*)malloc(FREADLENTH);
14 #define getc() (*(fread_ptr++))
15 #else
16 #define getc() getchar()
17 #endif
18 #define SetFile(x) ( freopen(#x".in", "r", stdin), freopen(#x".out", "w", stdout) )
19 using namespace std;
20 template<class T>inline void getd(T &x){
21 int ch = getc();bool neg = false;
22 while(!isdigit(ch) && ch != '-')ch = getc();
23 if(ch == '-')neg = true, ch = getc();
';
- ' + ch;
26 if(neg)x = -x;
27 }
28 /*******************************************************************************/
;
30 typedef long long LL;
31 #include
32 vector<int> adj[maxn];
33
34 int N, val[maxn], Begin[maxn], End[maxn], dep[maxn];
35
36 struct SegT{
37 int L, R, mid;
38 LL Sum, tg;
39 SegT *ls, *rs;
){
;
42 if(l == mid){
43 ls = rs = NULL;
44 return;
45 }
46 ls = new SegT(l, mid);rs = new SegT(mid, r);
47 }
;}
49 void Add(int l, int r, LL d){
50 if(l == L && r == R){
51 tg += d;push();
52 return;
53 }
54 push();
55 if(r <= mid)ls->Add(l, r, d);
56 else if(l >= mid)rs->Add(l, r, d);
57 else ls->Add(l, mid, d), rs->Add(mid, r, d);
58 Sum = ls->Sum + rs->Sum;
59 }
60 LL Query(int i){
61 if(tg)push();
62 if(L == mid)return Sum;
63 if(i < mid)return ls->Query(i);
64 if(i >= mid)return rs->Query(i);
65 }
66 }*R1, *R2;
67
68 void dfs(int cur, int p){
;
70 Begin[cur] = Iter++;
71 vector<int>::iterator it;
72 for(it = adj[cur].begin();it != adj[cur].end();++it)if(*it != p){
;
74 dfs(*it, cur);
75 }
76 End[cur] = Iter;
77 }
78
79 inline void init(){
80 int i, a, b;
;i <= N;++i)getd(val[i]);
;i < N;++i){
83 getd(a), getd(b);
84 adj[a].push_back(b);
85 adj[b].push_back(a);
86 }
, );
, N);R2 = , N);
;i <= N;++i)R1->Add(Begin[i], End[i], val[i]);
90 }
91
92 inline void opt1(){
93 int x, d;getd(x), getd(d);
94 R1->Add(Begin[x], End[x], d);
95 }
96
97 inline void opt2(){
98 int x, d;getd(x), getd(d);
- dep[x]) * d);
R2->Add(Begin[x], End[x], d);
}
inline void query(){
int x;getd(x);
printf("%lld\n", R1->Query(Begin[x]) + R2->Query(Begin[x]) * dep[x]);
}
int main(){
#ifndef DEBUG
SetFile(haoi2015_t2);
#else
freopen("test.txt", "r", stdin);
#endif
#ifdef FREAD
fread(fread_ptr, , FREADLENTH, stdin);
#endif
int M, opt;getd(N), getd(M);
init();
while(M--){
getd(opt);
)opt1();
)opt2();
else query();
}
#ifdef DEBUG
printf("\n%.3lf sec\n", (double)clock() / CLOCKS_PER_SEC);
#endif
;
}
dfs序列(区间修改+单点查询)
C.T3
有一个长度为N的数组,甲乙两人在上面进行这样一个游戏:
首先,数组上有一些格子是白的,有一些是黑的。然后两人轮流进行操作。每次操作选择一个白色的格子,假设它的下标为x。接着,选择一个大小在1~n/x之间的整数k,然后将下标为x、2x、...、kx的格子都进行颜色翻转。不能操作的人输。
现在甲(先手)有一些询问。每次他会给你一个数组的初始状态,你要求出对于这种初始状态他是否有必胜策略。假设两人总能做出最优决策。
对于30%的数据,N<=20;
对于50%的数据,N<=1000000;
对于70%的数据,N<=10000000;
对于100%的数据,N<=1000000000,K,W<=100,不会有格子在同一次询问中多次出现。
分析.
好难啊……TAT考场上果断30分暴搜……
出题人kzf告诉我们,可以修改一下游戏的定义:每一步可以选择黑格子或白格子,最终能将所有格子都翻成黑色的人赢。由于每次翻转黑格子的操作都不可能直接带来胜利,而任何一步选取黑格子进行的有利操作都能由对方通过再翻一次这个格子抵消掉,根据假设“两个人都是足够聪明的”,我们知道游戏中一定不会有人选择黑格子。这就保证了这种转换的正确性。
因此我们可以把每个黑色的位置都看成偶数个白格子叠加起来得到的,并将每个位置当做一个独立的游戏来计算SG函数,就可以套用常规的博弈题思路了。根据游戏规则,我们有$$SG(i) = \mathop{mex} \limits_{1 \leq k \leq N / i} \{ \mathop{\oplus } \limits_{2 \leq t \leq k} \{ SG(t*i) \}\}$$(其中mex(S)表示S中没有出现的最小自然数)按定义递推就可以拿到50分了。
考虑到当一个点i走到N要跳的步数一定时,我们可以把这些i的倍数的序列映射到另一个序列2...N/i,这样我们就可以用数学归纳证明每个点i的SG值只与从它跳到N需要的次数(即 N / i)有关。然后我们可以注意到,i从1到N中,N / i只会有O($\sqrt{N})$种取值,所以我们只需递推$O(\sqrt{N})$轮就可以了。然而……在递推时不论是维护一个指针线性递推还是用二分查找结构在线查找都只能拿到70分……
然后出题人kzf又告诉我们,存在很多相邻的按N/i划分的区间有着相同的SG值(原因大概是跳动次数增加时多跳的那一次改变的那些SG和不容易恰好等于增加之前的SG值?反正我不会证明……)。所以我们在预处理时只要判断是否能和上一块合并就可以了。复杂度……嗯……大概是O(玄学 × $N$)。不过实际跑起来还是挺快的……
Update: 考虑上面说的70分算法,在递推的过程中我们需要尽可能快地查询以前求出的SG值,那么我们直接用一个哈希表就可以解决问题了!(我以前还没写过哈希表……太弱啦……)时间复杂度大概是$T(N) = \sum_{i=1}^{\sqrt{N}} (\sqrt{\frac{N}{i}} + \sqrt{i} ) × \frac{N}{P}$,这个求出来大概是$O(\frac{N^{\frac{7}{4}}}{P})$,总算是不用玄学完美地解决了= =
代码.
2 /******************************Designed By Asm.Def****************************/
3 /*****************************************************************************/
4 #include
5 #include
6 #include
7 #include
8 #include
9 #include
#define SetFile(x) (freopen(#x".in", "r", stdin), freopen(#x".out", "w", stdout) )
//#define FREAD
#define FREADLENTH 5000000
#ifdef FREAD
char *fread_ptr = (char*)malloc(FREADLENTH);
#define getc() (*(fread_ptr++))
#else
#define getc() getchar()
#endif
using namespace std;
template<class T>inline void getd(T &x){
int ch = getc();bool neg = false;
while(!isdigit(ch) && ch != '-')ch = getc();
if(ch == '-')neg = true, ch = getc();
x = ch - ';
- ' + ch;
if(neg)x = -x;
}
/*******************************************************************************/
;//SG[len]
int N, val[maxn], vcnt, vt[maxn], checklist[maxn];
bool check[maxn];
int SG[maxn], id[maxn], idcnt;
#define ind(x) ( upper_bound(id, id + idcnt, x) - id - 1 )
inline void init(){
getd(N);
;
int ccnt;//回滚check数组
;i * i <= N;++i)val[vcnt++] = i;
for(j = N / i;j;--j)val[vcnt++] = N / j;
;i < vcnt;++i){
t = val[i];s = ccnt = vtcnt = ;
;j * j <= t;++j)vt[vtcnt++] = j;
for(j = t / j;j;--j)vt[vtcnt++] = t / j;//vt:能跳到的位置的N/i的所有取值
, j = vtcnt-;j >= ;--j){
while(id[it] > vt[j])--it;
tmp = SG[it];
c = t / vt[j] - t / (vt[j] + );//出现次数
check[checklist[ccnt++] = s ^ tmp] = true;
)s ^= tmp;
}
j = ;while(check[j])++j;
id[idcnt] = t;
if(j != lastSG)lastSG = SG[idcnt++] = j;
;j < ccnt;++j)check[checklist[j]] = false;
}
}
inline void work(){
int K, qcnt, sum, t;
getd(K);while(K--){
getd(qcnt);
sum = ;
while(qcnt--){
getd(t);
sum ^= SG[ind(N / t)];
}
if(sum)puts("Yes");
else puts("No");
}
}
int main(){
#ifdef DEBUG
freopen("test.txt", "r", stdin);
#else
SetFile(haoi2015_t3);
#endif
#ifdef FREAD
fread(fread_ptr, , FREADLENTH, stdin);
#endif
init();
work();
#ifdef DEBUG
printf("\n%.3lf sec\n", (double)clock() / CLOCKS_PER_SEC);
#endif
;
}
SG定理+递推+分块+玄学
;i * i <= N;++i)val[++vcnt] = i;
;i <= vcnt;++i){
;
;j * j <= t;++j)vt[vtcnt++] = j;
;j >= ;--j){
);)s ^= tmp;
;;j < ccnt;++j)check[checklist[j]] = ;
, FREADLENTH, stdin);
;
}
SG定理+递推+分块+哈希
D.set
刚开始你有一个数字0,每一秒钟你会随机选择一个[0,2^n-1]的数字,与你手上的数字进行按位或(C和C++的|,Pascal的or)操作。
选择数字i的概率是p[i]。保证0<=p[i]<=1,∑p[i]=1
问期望多少秒后,你手上的数字变成2^n-1。
对于30%的数据,n<=10
对于60%的数据,n<=15
对于100%的数据,n<=20
分析.
考场上我写了个错误的递推,不过我概率论学得渣不知道为什么不对,总之我在考场上尝试了很久都跑不出样例,最终直接输出个INF就放那了= =
换个思路,我们尝试用常规的期望的定义来求。设函数$f_k (S) $为第k轮集合为S的概率,那么答案就是
$$\sum_{i=1}^{\infty} i * (f_i (U) - f_{i-1} (U) )$$
不难写出函数f的递推式:
$$f_{i+1}(S) = \sum_a \sum_b [a \cup b = S] f_{i}(a) * P(b)$$
不过这个式子看上去不太好转移对吧?我们可以给它加个特技,不要管它们的并集是谁了,我们直接来考虑等式两边S集合的所有子集的函数值之和(这步变换可以通过集合论中的莫比乌斯反演来逆转),即:
$$\sum_{s' \subseteq S} f_{i+1}(s') = \sum_{a \subseteq S} \sum_{b \subseteq S} f_i(a) * P(b)$$
或$$\sum_{s' \subseteq S} f_{i+1}(s') = (\sum_{a \subseteq S} f_i(a) ) (\sum_{b \subseteq S} P(b))$$
发现了什么吗?某一项在一个集合上的答案的子集和恰好等于前一项上同一集合的子集和与这一集合的初始概率函数(也就是f_1函数)的子集和的乘积。换句话说,如果我们设$F_i (S) = \sum_{s' \subseteq S} f_i (s')$,那么我们的转移方程就可以写成$F_{i+1}(S) = F_i (S) * F_1 (S) $。瞬间变得非常简单有木有!!!什么求和都没有了,我们立刻就可以得到F的通项公式:$F_i (S) = (F_1 (S)) ^ i$.
那么现在我们的$F_i$函数就已知了,我们来看看怎么由$F_i$函数推出$f_i$。我们不妨令$f_i (S) = \sum_{S' \subseteq S} \mu(S', S) F_i(S')$,其中$\mu(S', S)$是我们要求的莫比乌斯函数(注意这里指的是集合论中广义的莫比乌斯反演)。将F代入,可得
$$f_i(S) = \sum_{S' \subseteq S} \mu(S', S) \sum_{S'' \subseteq S'} f_i(S'')$$ 由容斥原理可以得出,$\mu(S', S) = (-1)^{|S| - |S'|}$。从而我们可以得到:$$f_i (S) = \sum_{S' \subseteq S} (-1)^{|S| - |S'|} F_i(S')$$.代入$F_i$(S')的通项公式,可得:$$f_i(S) = \sum_{S' \subseteq S} (-1)^{|S| - |S'|} (F_1 (S')) ^ i)$$
那么我们的最终答案就可以表示为
或$$ \sum_{S' \subseteq S} (-1)^{|S| - |S'|} * ( - \sum_{i=0}^{\infty} F_1 (S')^i ) $$
由于F函数不会超过1,可直接利用幂级数求和得出答案:$$ \sum_{S' \subseteq S} (-1)^{|S| - |S'|} * ( \frac{1}{F_1(S') - 1} ) $$
而计算一个函数的子集和函数可以用标程中给出的代码用$O(n2^n)$的时间复杂度求出。这样,这道题就完美解决啦!
代码.
2 /**********************By Asm.Def-Wu Jiaxin*****************************/
3 /***********************************************************************/
4 #include
5 #include
6 #include
7 #include
8 #include
9 #include
using namespace std;
#define SetFile(x) ( freopen(#x".in", "r", stdin), freopen(#x".out", "w", stdout) );
//#define UseFREAD
#ifdef UseFREAD
#define getc() *(file_ptr++)
#define FreadLenth 5000000
char CHARPOOL[FreadLenth], *file_ptr = CHARPOOL;
#else
#define getc() getchar()
#endif
#ifdef DEBUG
#include
timeb SysTp;
#endif
template<class T>inline void getd(T &x){
char ch = getc();bool neg = false;
while(!isdigit(ch) && ch != '-')ch = getc();
if(ch == '-')ch = getc(), neg = true;
x = ch - ';
- ' + ch;
if(neg)x = -x;
}
/***********************************************************************/
<< ;
;
double P[maxn];
int n, N;
inline ? -x : x;}
inline void work(){
getd(n);N = << n;
int i, j, t, tmp;
;i < N;++i){
scanf("%lf", P + i);
if(P[i])tmp |= i;
}
!= N){
puts("INF");
return;
}
;t < N;t <<= )//Modulate
;j < N;++j)if(j & t)P[j] += P[j ^ t];
;j < N;++j){
;
else P[j] = 1.0 / (P[j] - 1.0);
}
;t < N;t <<= )//Demodulate
;j < N;++j)if(j & t)P[j] -= P[j ^ t];
printf(]);
}
int main(){
#ifdef DEBUG
freopen("test.txt", "r", stdin);ftime(&SysTp);
size_t Begin_sec = SysTp.time, Begin_mill = SysTp.millitm;
#elif !defined ONLINE_JUDGE
SetFile(haoi2015_set);
#endif
#ifdef UseFREAD
fread(file_ptr, , FreadLenth, stdin);
#endif
work();
#ifdef DEBUG
ftime(&SysTp);
printf("\n%.3lf sec \n", (SysTp.time - Begin_sec) + (SysTp.millitm - Begin_mill) / 1000.0);
#endif
;
}
集合多项式+莫比乌斯反演
E.str
你有一个长度为n的数字串。
定义f(S)为将S拆分成若干个1~m的数的和的方案数,比如m=2时,f(4)=5,分别为4=1+1+1+1, 4=1+1+2, 4=1+2+1, 4=2+1+1, 4=2+2
你可以将这个数字串分割成若干个数字(允许前导0),将它们加起来,求f,并求和。
比如g(123)=f(1+2+3)+f(1+23)+f(12+3)+f(123)。
已知字符串和m后求答案对998244353(7*17*223+1,一个质数)取模后的值。
对于30%的数据,字符串长度不超过5
对于60%的数据,字符串长度不超过18
对于100%的数据,字符串长度不超过500,m<=5
分析.
不难看出,$f(i) = \sum_{j=1}^m f(i-j)$.很容易把这个递推式写成一个m × m的矩阵M。暂时撇开f函数前m项构成的向量$F_0$,我们考虑对这整个转移矩阵做dp。设g(i)表示能够将$F_0$转移到$F_{num_{0, i}}$的转移矩阵。其中$num_{i, j}$表示字符串的第i+1到j位构成的十进制数。
根据矩阵乘法对加法的分配律,可以得到$g(i) = \sum_{j = 0}^{i-1} g(j) * M ^ {num(j, i)}$,先用十进制矩阵快速幂的思路求出F的10的各幂次的幂,然后dp求出最终的矩阵,最后左乘向量求值即可。总复杂度$O({len}^2 m^3)$ 。值得注意的是……这题卡常数,矩阵乘法一定要尽量减少取模的次数。
];
][];}I, F, dp[maxn], Pow[][maxn], Pow10[];
;i < n;++i);j < n;++j){
;
;k < n;++k)tmps += (LL)a.A[i][k] * b.A[k][j];
;i < n;++i);j < n;++j){
)ans = ans * a;a = a * a;t >>= ;}
;;i < n;++i);j < i;++j)Vect[i] += Vect[j];
;i < n;++i)F.A[i][i-] = ;
;i < n;++i)F.A[i][n-] = ;
;i < n;++i)I.A[i][i] = ;
] = I;Pow10[] = F;
;i < ;++i)Pow10[i] = Pow10[i-] * F;
;i < ;++i){
] = tmp;
;j <= len;++j)Pow[i][j] = power(Pow[i][j-], );
] = I;
;i <= len;++i){
;j <= i;++j){
;
;i < n;++i)Ans = ((LL)dp[len].A[i][] * Vect[i] + Ans) % mod;
printf( }
#ifdef DEBUG
freopen( SetFile(haoi2015_str);
#ifdef UseFREAD
fread(file_ptr, , FreadLenth, stdin);
init();
work();
#ifdef DEBUG
printf( ;
}
矩阵+十进制快速幂+dp
河南省队选拔 HAOI2015 解题报告的更多相关文章
- 重庆市队选拔 CQOI2015 解题报告
文章链接:http://www.cnblogs.com/Asm-Definer/p/4434601.html 题目链接:http://pan.baidu.com/s/1mgxIKli 官方数据:htt ...
- 习题: codevs 2492 上帝造题的七分钟2 解题报告
这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...
- 2011 ACM-ICPC 成都赛区解题报告(转)
2011 ACM-ICPC 成都赛区解题报告 首先对F题出了陈题表示万分抱歉,我们都没注意到在2009哈尔滨赛区曾出过一模一样的题.其他的话,这套题还是非常不错的,除C之外的9道题都有队伍AC,最终冠 ...
- 杭州电子科技大学Online Judge 之 “确定比赛名次(ID1285)”解题报告
杭州电子科技大学Online Judge 之 "确定比赛名次(ID1285)"解题报告 巧若拙(欢迎转载,但请注明出处:http://blog.csdn.net/qiaoruozh ...
- 【原创】leetCodeOj --- Sliding Window Maximum 解题报告
天,这题我已经没有底气高呼“水”了... 题目的地址: https://leetcode.com/problems/sliding-window-maximum/ 题目内容: Given an arr ...
- 冲刺Noip2017模拟赛1 解题报告——五十岚芒果酱
题1 国际象棋(chess) [问题描述] 有N个人要参加国际象棋比赛,该比赛要进行K场对弈.每个人最多参加2场对弈,最少参加0场对弈.每个人都有一个与其他人都不相同的等级(用一个正整数来表示).在对 ...
- ZROIDay4-比赛解题报告
ZROIDay4-比赛解题报告 扯闲话 感觉这个出题人的题做起来全都没感觉啊,今天又凉了,T1完全不知道什么意思,T2只会暴力,T3现在还不懂什么意思,真的太菜了 A 题意半天没搞懂爆零GG了,讲了一 ...
- CH Round #56 - 国庆节欢乐赛解题报告
最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...
- 二模13day1解题报告
二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...
随机推荐
- Strusts2笔记8--文件的上传和下载
文件的和上传和下载: (1)文件的上传: Struts是通过拦截器实现文件上传的,而默认拦截器栈中包含了文件上传拦截器,故表单通过Struts2可直接将文件上传,其底层是通过apache的common ...
- ModelState验证部分属性
ModelState.Remove("Name") 去掉不需要验证的属性.
- 工作常用shell集合
<1>日志回滚案例======>[root@localhost test]# cat hbase.sh hbase_rotate_log () { log=$1; ...
- 数据库-mysql中文显示问题
一:在mysql 下面查看带中文的记录显示乱码 mysql> select * from role; +----+------+ | id | name | +----+------+ | 1 ...
- SQL SERVER中查询某个表或某个索引是否存在
查询某个表是否存在: 在实际应用中可能需要删除某个表,在删除之前最好先判断一下此表是否存在,以防止返回错误信息.在SQL SERVER中可通过以下语句实现: IF OBJECT_ID(N'表名称', ...
- 基于docker 搭建Elasticsearch6.2.4(centos)
一.介绍 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticsearch是用Java开发的,并作为 ...
- Fix Valgrind's must-be-redirected error in Gentoo
Last week, I tried to use Valgrind to identify potential memory related bugs, since segmentation fau ...
- 分析Windows的死亡蓝屏(BSOD)机制
这篇文章本来是投Freebuf的,结果没过.就贴到博客里吧,图懒得发上来了 对于Windows系统来说,被人们视为洪水猛兽的蓝屏也是一种有利于系统稳定的机制.蓝屏其实是Windows系 统的一种自查机 ...
- google浏览器打开新的标签页显示http://www.google.com.hk/url?sa=p&hl=zh-CN&……
chrome的版本:51.0.2704.106 m使用该版本的chrome后,每次打开新标签页,都会提示“无法访问此网站”.并自动跳转到一个地址“http://www.google.com.hk/ur ...
- ubuntu安装redis 和可视化工具
方式一: 下载地址:http://redis.io/download,下载最新文档版本. 本教程使用的最新文档版本为 2.8.17,下载并安装: $ wget http://download.redi ...