前段时间终于配置好了TopCoder的环境,所以就拿这场的DIV2练习了一下

1. 250pt FoxAndSightseeing

题意

给你n个城市的位置,他们在同一直线上,要求你跳过其中某一个城市,按顺序依次访问其他的城市,求距离的最小值

题解

由于数据规模为n<=50,所以直接枚举就好

代码:

  1. class FoxAndSightseeing
  2. {
  3. public:
  4. int getMin(vector <int> position)
  5. {
  6. int ans=INF;
  7. for(int i=;i<position.size()-;i++)
  8. {
  9. int sum=,pre=position[];
  10. for(int j=;j<position.size();j++)
  11. {
  12. if(j==i) continue;
  13. sum+=abs(position[j]-pre);
  14. pre=position[j];
  15. }
  16. if(sum<ans) ans=sum;
  17. }
  18. return ans;
  19. }
  20. };

2. 500pt ColorfulRoa

题意

给定n个点,每个点有一个颜色(R,G,B分别表示红绿蓝),要求你选择其中的一些点,使得总花费最少。在选择的点中,相邻的两点之间有一个花费,假设选择了i和j,那么花费就是(i-j)*(i-j),另外要求你选择的点的颜色按顺序依次是R,G,B,R,G,B。。。。

题解

很水的DP,方程为dp[i]=min(dp[i],dp[j]+(i-j)*(i-j))((cr[j]=='R'&&cr[i]=='G')||(cr[j]=='G'&&cr[i]=='B')||(cr[j]=='B'&&cr[i]=='R'))

代码:

  1. int dp[];
  2. bool check(char a,char b)
  3. {
  4. return (a=='R'&&b=='G')||(a=='G'&&b=='B')||(a=='B'&&b=='R');
  5. }
  6. class ColorfulRoad
  7. {
  8. public:
  9. int getMin(string road)
  10. {
  11. int i,j;
  12. memset(dp,INF,sizeof(dp));
  13. dp[]=;
  14. FOR(i,,road.size()-)
  15. REP(j,i)
  16. if(check(road[j],road[i]))
  17. dp[i]=min(dp[i],dp[j]+(i-j)*(i-j));
  18. return dp[road.size()-]==INF?-:dp[road.size()-];
  19. }
  20. };

3. 1000pt SparseFactorialDiv2

题目大意

对于整数n,我们定义F(n) = (n - 0^2) * (n - 1^2) * (n - 2^2) * (n - 3^2) * ... * (n - k^2),k为使得n-k^2>0的最大整数。给定lo,hi,和p(是一个素数),请你计算lo<=n<=hi中能够使得F(n)可以被divisor整除的n的个数

题解

因为p是素数,如果F(n)能够被p整除,说明F(n)的某一个因子(n-i^2)可以被p整除

用数学表示为(n-i^2)%p==0

n≡i^2(mod p)

n=i^2+x*p

那么对于每一个i,我们就有x=(n-i^2)/p个符合情况,我们只需要枚举i即可,不过需要注意一点的是这样会重复计算,因此如果i^2≡j^2(mod p)(i<j) 那么如果在j的时候的x也算入答案中的话就多算了,因为我们在i的时候已经计算过了,那如何处理这种情况呢?只需要对余数判重即可,即如果i^2%p已经存在,那么此时的x不计入答案,把没个符合要求的x累加起来就是最终的答案

代码:

  1. map<LL,int>ms;
  2. LL getAns(LL r,LL p)
  3. {
  4. ms.clear();
  5. LL ans=;
  6. for(LL i=; i*i<=r; i++)
  7. {
  8. if(ms[i*i%p]) continue;
  9. ans+=(r-i*i)/p;
  10. ms[i*i%p]++;
  11. }
  12. return ans;
  13. }
  14. class SparseFactorialDiv2
  15. {
  16. public:
  17. LL getCount(LL lo, LL hi, LL divisor)
  18. {
  19. return getAns(hi,divisor)-getAns(lo-,divisor);
  20. }
  21. };

SRM 596 DIV 2的更多相关文章

  1. TopCoder SRM 596 DIV 1 250

    body { font-family: Monospaced; font-size: 12pt } pre { font-family: Monospaced; font-size: 12pt } P ...

  2. Topcoder口胡记 SRM 562 Div 1 ~ SRM 599 Div 1

    据说做TC题有助于提高知识水平? :) 传送门:https://284914869.github.io/AEoj/index.html 转载请注明链接:http://www.cnblogs.com/B ...

  3. TopCoder SRM 560 Div 1 - Problem 1000 BoundedOptimization & Codeforces 839 E

    传送门:https://284914869.github.io/AEoj/560.html 题目简述: 定义"项"为两个不同变量相乘. 求一个由多个不同"项"相 ...

  4. 竞赛图的得分序列 (SRM 717 div 1 250)

    SRM 717 DIV 1 中 出了这样一道题: 竞赛图就是把一个无向完全图的边定向后得到的有向图,得分序列就是每个点的出度构成的序列. 给出一个合法的竞赛图出度序列, 要求构造出原图(原题是求(u, ...

  5. TopCoder SRM 667 Div.2题解

    概览: T1 枚举 T2 状压DP T3 DP TopCoder SRM 667 Div.2 T1 解题思路 由于数据范围很小,所以直接枚举所有点,判断是否可行.时间复杂度O(δX × δY),空间复 ...

  6. Topcoder SRM 648 (div.2)

    第一次做TC全部通过,截图纪念一下. 终于蓝了一次,也是TC上第一次变成蓝名,下次就要做Div.1了,希望div1不要挂零..._(:зゝ∠)_ A. KitayutaMart2 万年不变的水题. # ...

  7. SRM 596 DIV2

    250pt: 直接枚举跳过的位置求和即可. int n,m; int ABS(int a) { ) return (-a); else return a; } class FoxAndSightsee ...

  8. SRM 638 Div.2

    250 给一个字符串 要求从一种形式换成另一形式 class NamingConvention{ private: int a, b, c; public: int d; string toCamel ...

  9. [topcoder]SRM 646 DIV 2

    第一题:K等于1或者2,非常简单.略.K更多的情况,http://www.cnblogs.com/lautsie/p/4242975.html,值得思考. 第二题:http://www.cnblogs ...

随机推荐

  1. Angular.js入门的样例

    感觉这下子,前端的路也宽多了,从容不迫了. 因为可控制的节点又推前了, 有空了好好学一下. 然后结合EXPRESS或METEOR,是不是有点爽? 参考URL: https://toddmotto.co ...

  2. highcharts 柱形堆叠图

    <!doctype html> <html lang="en"> <head> <script type="text/javas ...

  3. undefined与null的区别---js

    不错... http://www.ruanyifeng.com/blog/2014/03/undefined-vs-null.html

  4. [topcoder]AvoidRoads

    二维动态规划.和某一道leetcode的题目差不多.就是多了blocks的数组或集合. 本次解题的心得有:1.根据题意使用集合表示阻碍:2.使用字符串的形式表示整数的pair,简洁明了:3.p1到p2 ...

  5. mybatis知识点

    1.Mybatis比IBatis比较大的几个改进是什么 a.有接口绑定,包括注解绑定sql和xml绑定Sql , b.动态sql由原来的节点配置变成OGNL表达式, c. 在一对一,一对多的时候引进了 ...

  6. Android:requestWindowFeature应用程序窗体显示状态操作

    注意requestWindowFeature必须在 setContentView()之前调用. 1.DEFAULT_FEATURES:系统默认状态,一般不需要指定 2.FEATURE_CONTEXT_ ...

  7. 179. Largest Number

    题目: Given a list of non negative integers, arrange them such that they form the largest number. For ...

  8. Android 自定义Button按钮显示样式(正常、按下、获取焦点)

    现在的用户对APP的外观看得很重要,如果APP内所有元件都用Android默认样式写,估计下面评论里就有一堆在骂UI丑的.今天学习自定义Button按钮样式.Button样式修改的是Button的背景 ...

  9. 深入研究Java类加载机制

    类加载是Java程序运行的第一步,研究类的加载有助于了解JVM执行过程,并指导开发者采取更有效的措施配合程序执行. 研究类加载机制的第二个目的是让程序能动态的控制类加载,比如热部署等,提高程序的灵活性 ...

  10. 【php】对PHPExcel一些简单的理解

    这里有关于excel文件的几个概念需要跟大家说明一下,这几个概念对于我们的后续编程是很有帮助的:1.工作簿:在excel环境中用来存储数据并处理数据的文件,又称为excel文件或excel文档,   ...