zoukankan      html  css  js  c++  java
  • 我一万年也不更新一次博客

    sgu 270-280

    • sgu270
      分类讨论,考虑各种各样的情况
    • sgu271
      简单的splay翻转
    • sgu272
      题目只需要找出任意一种合法方案,那么一遍一遍dfs直到dfs不动了就行了
    • sgu273
      题意是给你一个由b,r,w,y组成的串,并且给定若干个规则,每个规则的意思是相邻的两个字母可以合并成另一个字母,问这个串最终能合并成哪几个字母。
      DP。(f[i][j][c])表示能否把子串([i,j])变成字符c。
    • sgu274
      按题意模拟
    • sgu275
      n个数里选k个,使得异或和最大
      逐位处理,尽可能让高位的异或和为1。
      补个链接:http://dtyfc.com/acm/962
    • sgu276
      弱智题
    • sgu277
      动态凸包
    • sgu278
      每种原料有两种代价属性A、B和一个价值属性C,每种原料可以取任意量(可以非整数),问不超过两种代价上限的情况下C的最大值。
      首先因为可以取任意非整数量,所以三个属性可以规约为两个。可以计算出一个单位C对应的A和B。
      然后如果把A和B看做点((A,B)),那么平面上n个点中只有凸包边上的点有可以选择的价值。因为对于凸包里面的点肯定存在凸包边上点两种属性都比它更优。
      接下来,因为我们需要C的和最大,每种原料又可以去任意量,所以最终的选取方案中,A和B的比值一定等于A和B上限的比值。而且我们只需要最多两种原料调和比例就可以了。所以我们取线段((0,0))((A_{max},B_{max})),这条线段和凸包的交点就是我们要求的答案了。
    • sgu279
      贪心
    • sgu280
      按照一个什么规则贪心?(我没想明白)

    CF && BC

    • CF#296 B
      问题等价于有一堆线段,选取最多的一堆线段使得任意两个线段都不相交。
      按照线段右端点排序,能加入当前这条线段就加入,否则就不加入。
      因为如果你非要把当前这个加不进来的线段加进来,那么你就必须去掉之前选过的至少一条线段,还会造成已选择区间的右端点右移,这显然是不合适的。
    • BC#33 C
      (2^{30})枚举不了的时候可以考虑分别枚举两个(2^{15}),并且用贪心把这两个连起来。
  • 相关阅读:
    nodejs发送http请求
    Codeforces Round #655 (Div. 2)
    闇の連鎖 树上LCA + 树上差分
    Tree 换根dp
    「水」悠悠碧波 kmp
    HH的项链
    Educational Codeforces Round 90 (Rated for Div. 2)
    巡逻(论为什么第二次求直径要用dp)
    Codeforces Round #651 (Div. 2)
    Treap板子
  • 原文地址:https://www.cnblogs.com/loveidea/p/4351936.html
Copyright © 2011-2022 走看看