NeoRuTayE's blog

Archives · 2019

Home

About

Archives

🧸

ACMCC++

Codeforces1077C - Good Array

Good Array 题目大意就是对于一个有限数列,如果其中一个元素可以表示为数列中其他所有元素的和,则这个数列(数组)被称为Good Array。现在有一个数列a,请找出所有的元素,使得删去这些元素后这个数列为Good Array

Read more
ACMCC++组合数学

HDU4015 - Mario and Mushrooms( The 36th ACM/ICPC Asia Regional Shanghai Site —— Warmup E题)

Mario and Mushrooms 一道数学题,和pzc推了差不多一小时的式子,结果还是错了OTZ,遂看题解 然后发现这题其实就是直接把Raney引理套一套就行了(Raney引理又是什么神仙???) Raney引理: 设整数序列A={Ai,i=1,2,…,N},且部分和为Sk=A1+,…,+Ak,序列中的所有的数字之和为Sn=1;则在A的N个循环表示中,有且仅有一个序列B,满足B的任意部分和Si均大于零。 一篇文章: HDOJ4105和raney引理 所以当时为什么不直接打表 代码如下: #include <cstdio> #include <iostream> #include <cstring> #include <cmath> #include ..

Read more
loading..
ACMCC++图论拓补排序反向建图

HDU2647 - Reward

Reward 其实就是用拓补排序判一下环,但需要注意两点:一是反向建图。这主要是为了计算奖金时的方便,因为反向建图就可以从奖金最少的那个人出发,遍历整个图,逐步累加得到答案;如果是正向建图,则需要先找到奖金最少的那个人,将他作为起点......二是这道题其实是根据每个点(人)在图中的深度来确定每个点(人)的奖金的。已下图为例: 3和4的深度是一样的,所以两者的奖金也一样。因此,不能简单地认为,如果可以拓补排序了,答案就是888 + (n * (n - 1)) / 2 代码如下: #include <cstdio> #include <iostream> #include <cstring> #include <cmath> #include <a..

Read more
12