多校题解

##[1001.Average](http://acm.hdu.edu.cn/showproblem.php?pid=5353)
Summary
n people are sitting around a circle and every two adjacent people can exchange only on candy. The goal is to find a valid exchange order to make everyone have equal amount of candies (or determine it is impossible). Solution

    Find the sum of the candies. If the sum is not a multiple of n, such order does not exist.
    let ci be the difference between the candies i-th person have and the average candies.
    Enumerate 1-st person’s operation: give a candy to 2, receive a candy from 2, do nothing.
    Then determine next one’s operation according to the value ci:

    ci= −1: receive a candy from i + 1.
    ci = 0: just do nothing.
    ci = 1: give a candy to i + 1.
    otherwise, we can not find a valid exchange order.

Time complexity: O(n).   
##[1002.Bipartite Graph](http://acm.hdu.edu.cn/showproblem.php?pid=5354) Summary
We are given an undirected graph G with n vertices and m edges. You are to determine for each vertex i, after deleting it, whether the graph becomes a bipartite graph. Solution

    For every edge (u,v), set a time interval [s,t), which means the edge is only available from time s to time t.
    Every deletion will make some edges become unavailable at some time points. More specifically, if we delete i-th vertex, every edge adjacent to vertex i will unavailable at time i. Then the number of available time intervals for each edge will be at most 3.

    If we know whether the graph is a bipartite graph at a specific time i, we also know whether i-th vertex satisfy our will.

  Solve the problem:   You are given an undirected graph G with n vertices and m edges. Each edge will available only in a specific time interval [st,ed). For every time t, you are to determine whether the graph is a bipartite graph.

    Let function Solve(l,r) solve all time from l to r and E(l,r) is a set of edges which can exist at some time in interval [l,r).

    Let mid = l+r2, for each edge in E, assume the interval is [x,y):

    x=l,y=r, add the edge and check if it forms an odd circle with other edges added before.
    ymid, add the edge to set E(l,mid).
    xmid, add the edge to set E(mid,r).
    otherwise, add the edge to both sets E(l,mid) and E(mid,r).

    We can use disjoint-set to maintain odd circles. After each Solve(l,r), remember to resume the disjoint-set.

  How to resume the disjoint-set:

    Just union by rank and there is no need to use path compression.
    Before every union operation, use a stack to store the state before.
    Resuming the disjoint-set is just to restore the state according to the stack.

Time complexity: O(m log2 n)   ##[1003.Cake](http://acm.hdu.edu.cn/showproblem.php?pid=5355) Summary You are given n integers 1, 2, . . . , n and an integer m. You need to divide the n integer into m equal sum parts (or determine it is impossible). Solution

    If m is not divisible by n(n+1)2 or n<2m1, it is impossible.
    If we have 2m number 1, 2, . . . , 2m, we can divide it into m equal sum parts easily.
    If n is large, we can reduce n to n2m. If n(n40) is small, we can use backtracking to find a possible solution or we can construct the solution by hand.

Time complexity: O(n).   ##[1004.Deal](http://acm.hdu.edu.cn/showproblem.php?pid=5356) Summary Given are a weighted tree with n vertices. There’s an item with weight wi in i-th vertex. The cost for transporting an item with weight w from vertex u to vertex v is w multiply the distance from vertex u to vertex v. Item will be cached in the vertex it passed. You are going to make m transportations and make the sum of cost maximum. Each item will be transported from a vertex containing it and closet to the destination.   Solution

    Each item is independent, so just consider item by item.
    For item i, the first transportation must be the longest, same as the second transportation and so on.
    Using greedy to find the path. Sort all the possible transportations and get the largest m.

Time complexity: O(n2 log n).     ##[1005.Easy Sequence](http://acm.hdu.edu.cn/showproblem.php?pid=5357) Summary You are given a parentheses string. For i-th character, you need to find the number valid strings starting with it or ending with it. For i-th character, you need to find the number valid substrings containing it. Solution

    let matchi be the position of matched parenthese for i-th character, ai be the number of valid substrings starting with i-th character, and bi be the number of valid substrings ending with i-th character.

ai=amatchi+1+1, bi=bmatchi1+1

    assume si is ’(’, let upi be smallest matched parentheses contain si and smatchi

ansi=ansmatchi=ansupi+aibmatchi

    both matchi and upi can be computed by using a stack.

Time complexity: O(n).   ##[1006.First One](http://acm.hdu.edu.cn/showproblem.php?pid=5358) Summary For a given sequence a1, a2, . . . , an, we want to find the value of i=1nj=in(log2S(i,j)+1)(i+j) Whrer S(i ,j) is the sum of ai,ai+1,…,aj Solution

    log2x+1 is the number of bits in the binary representation of x.
    Consider the contribution of k-th bit: if S(i,j)2k ,i+j is added to the answer.
    Enumerate k-th bit, and use two pointers to maintain the contribution.

Time complexity: O(n log n).     ##[1007.Group](http://acm.hdu.edu.cn/showproblem.php?pid=5359) Summary We are given an directed graph G with n vertices and m edges. You are to determine for each edge i,after deleting it, whether the number of strongly connected components increases. Solution Let us first solve the vertex deleting one:

    Find all the strongly connected components, each strongly connected component can be considered independently.
    Let G=(V,E) is a strongly connected graph, GR=(V,ER) is the reversal graph of G (if (u,v) in G then (v,u) in GR), G(s)=(V,E,s) be the flowgraph with start vertex s,D(s) the set of non-trivial dominators in G(s), GR(s)=(V,ER,s) be the flowgraph with start vertex s, DR(s) the set of non-trivial dominators in GR(s).
    Then vertex vs is a strong articulation point in G if and only if vD(s)DR(s).
    proving it is not easy, you may google it if you have interest.

Now let us solve the edge deleting one: for each edge xy, add an extra vertex z between the edge, xzy. We can use the mothod above to solve it. Time complexity: O((n+m)α(n+m))   ##[1008.Hiking](http://acm.hdu.edu.cn/showproblem.php?pid=5360) Summary There are n people and i-th people will go out if the number of people going out if no less than li+1 and no larger than ri+1. You need to invite them one by one to make the number of people going out as large as possible. Solution

    sort all the people according to li and ri.
    maintain an integer cur as the number of people agree to go out yet. For all the people will agree to go out, pick the one with smallest r.

Time complexity: O(n log n).   ##[1009.In Touch](http://acm.hdu.edu.cn/showproblem.php?pid=5361) Summary n vertices are in a straight line and i-th vertex is in position i. i-th vertex can teleport to other vertices whose distance between i-th vertex is no less than li and no larger than ri with cost ci. For each vertex,find the minimum cost from 1-st vertex to it. Solution

    let di be the cost entering vertex i.
    use dijkstra to calculate di and use disjoint-set to maintain the vertex not visited yet.
    the answer is dici.

Time complexity: O(n log n).   ##[1010.Just A String](http://acm.hdu.edu.cn/showproblem.php?pid=5362) Summary You are given a random string of length n and an alphabet of size m. You are to tell the expected number of such substrings that can be rearranged to a palindrome in the random string. Solution

    The answer is obvious after enumerating the length of the substring:

l=1n(nl+1)mnlT(l,m) where T(l,m) is the number of such string with length l and alphabet of size m.

    l can be odd or even, let’s solve the even case first:

——T(2n,m)=i=0n(2i,m1)(2n2i) ——T(2n,m)(2n)!=i=0nT(2i,m1)(2i)!1(2(ni))! ——Let Gm(x) be the generating function for T(2n,m)(2n)! , F(x) be the generating function for 1(2n)!. Then F(x)=coshx=ex+ex2and Gm(x)=Fm(x)=(ex+ex2)m. ——T(2n,m) is the coefficient of n-th item of Gm(x), after doing some calculation, we have T(2n,m)=i=0m12(mi)(m2i)2n2m1 For a fixed n, which can be computed in O(m) time.

    Now it is time for the odd l:

T(2n+1,m)=i=0nT(2i,m1)(2n+12i) If we precompute the value for T(2i,m1) then T(2n+1,m) can be computed in O(n) time. Time complexity: O(n(m+n)).   ##[1011.Key Set](http://acm.hdu.edu.cn/showproblem.php?pid=5363) Summary For a given set {1, 2, . . . , n}, you are to find the number of nonempty subsets with even sum. Solution Let a be the number of even integers and b be the number of even integers. The answer is: 2a((b0)+(b2)+)=2a+b1=2n11 Time complexity: O(log n)

posted @   Pat  阅读(358)  评论(0编辑  收藏  举报
编辑推荐:
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
阅读排行:
· DeepSeek V3 两周使用总结
· 回顾我的软件开发经历(1)
· C#使用yield关键字提升迭代性能与效率
· 低成本高可用方案!Linux系统下SQL Server数据库镜像配置全流程详解
· 4. 使用sql查询excel内容
历史上的今天:
2015-11-22 HDU 2255 奔小康发大财
点击右上角即可分享
微信分享提示