zoukankan      html  css  js  c++  java
  • 多校题解

    ##[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 $c_{i}$ 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 $c_{i}$:

        $c_{i}$= −1: receive a candy from $i$ + 1.
        $c_{i}$ = 0: just do nothing.
        $c_{i}$ = 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 = $frac{l+r}{2}$, 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.
        $y leq mid$, add the edge to set $E(l,mid)$.
        $x geq mid$, 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 log^{2}  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 $frac {n(n+1)}{2}$ or $n < 2m - 1$, it is impossible.
        If we have 2$m$ number 1, 2, . . . , 2$m$, we can divide it into $m$ equal sum parts easily.
        If $n$ is large, we can reduce $n$ to $n - 2m$. If $n (n leq40)$ 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 $w_{i}$ 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(n^{2}  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 $match_{i}$ be the position of matched parenthese for $i$-th character, $a_{i}$ be the number of valid substrings starting with $i$-th character, and $b_{i}$ be the number of valid substrings ending with $i$-th character.

    $a_{i}=a_{match_{i+1}}+1$, $b_{i}=b_{match_{i-1}}+1$

        assume $s_{i}$ is ’(’, let $up_{i}$ be smallest matched parentheses contain $s_{i}$ and $s_{match_{i}}$

    $ans_{i}=ans_{match_{i}}=ans_{up_{i}}+a_{i}*b_{match_{i}}$

        both $match_{i}$ and $up_{i}$ 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 $a_{1}$, $a_{2}$, . . . , $a_{n}$, we want to find the value of $sum_{i=1}^{n} sum_{j=i}^{n}(left lfloor log_{2} S(i ,j) ight floor+1)*(i+j)$ Whrer S(i ,j) is the sum of $a_{i}$,$a_{i+1}$,…,$a_{j}$ Solution

        $left lfloor log_{2}x ight floor +1$ is the number of bits in the binary representation of $x$.
        Consider the contribution of $k$-th bit: if $S(i, j)geq 2^{k}$ ,$ 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, $G^{R} = (V,E^{R})$ is the reversal graph of $G$ (if $(u, v)$ in $G$ then $(v, u)$ in $G^{R}$), $G(s) = (V,E, s)$ be the flowgraph with start vertex $s$,$D(s)$ the set of non-trivial dominators in $G(s)$, $G^{R}(s) = (V,E^{R}, s)$ be the flowgraph with start vertex $s$, $D^{R}(s)$ the set of non-trivial dominators in $G^{R}(s)$.
        Then vertex $v eq s$ is a strong articulation point in $G$ if and only if $v in D(s)cup D^{R}(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 $x ightarrow y$, add an extra vertex $z$ between the edge, $x ightarrow z ightarrow y$. We can use the mothod above to solve it. Time complexity: $O((n + m) alpha (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 $l_{i} + 1$ and no larger than $r_{i} + 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 $l_{i}$ and $r_{i}$.
        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 $l_{i}$ and no larger than $r_{i}$ with cost $c_{i}$. For each vertex,find the minimum cost from 1-st vertex to it. Solution

        let $d_{i}$ be the cost entering vertex $i$.
        use dijkstra to calculate $d_{i}$ and use disjoint-set to maintain the vertex not visited yet.
        the answer is $d_{i}-c_{i}$.

    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:

    $sum_{l=1}^{n}(n-l+1)m^{n-l}T(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)=sum_{i=0}^{n}(2i,m-1)* egin{pmatrix}2n\2i end{pmatrix}$ ——$frac {T(2n,m)}{(2n)!}=sum_{i=0}^{n}frac {T(2i,m-1)}{(2i)!}*frac{1}{(2(n-i))!}$ ——Let $G_{m}(x)$ be the generating function for $frac{T(2n,m)}{(2n)!}$ , F(x) be the generating function for $frac {1}{(2n)!}$. Then $F(x)=cosh sqrt {x}=frac{e^{sqrt{x}}+e^{-sqrt{x}}}{2} $and $G_{m}(x)=F^{m}(x)=( frac{e^{sqrt{x}}+e^{-sqrt{x}}}{2})^{m}$. ——$T(2n,m)$ is the coefficient of $n$-th item of $G_{m}(x)$, after doing some calculation, we have $T(2n,m)=sum_{i=0}^{frac{m-1}{2}}frac{egin{pmatrix}m\i end{pmatrix}*(m-2i)^{2n}}{2^{m-1}}$ For a fixed $n$, which can be computed in $O(m)$ time.

        Now it is time for the odd $l$:

    $T(2n+1,m)=sum_{i=0}^{n}T(2i,m-1)* egin{pmatrix}2n+1\2i end{pmatrix}$ If we precompute the value for $T(2i,m - 1)$ 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: $2^{a}(egin{pmatrix}b\0 end{pmatrix}+egin{pmatrix}b\2 end{pmatrix}+$…$)=2^{a+b-1}=2^{n-1}-1$ Time complexity: $O(log n)$

  • 相关阅读:
    windows笔记进程的句柄
    windows笔记创建线程的函数CreateThread
    c#实现从其他网站抓取imei码信息,手工输入验证码
    Linux下自动修改用户密码的方法(直接通过命令而不是在终端输入密码)
    Redis学习笔记List数据类型
    在Linux(centos)上安装PHP的mongodb扩展
    CI(codeigniter)如何防止sql注入
    MongoDB增加用户认证: 增加用户、删除用户、修改用户密码、读写权限、只读权限
    Sublime Text编辑器如何显示顶部的菜单栏
    C#图片选择器
  • 原文地址:https://www.cnblogs.com/Patt/p/5836400.html
Copyright © 2011-2022 走看看