上一页 1 ··· 4 5 6 7 8

2013年6月11日

【转】POJ 题目整理

摘要: 原地址:http://wenku.baidu.com/view/42d690134431b90d6c85c7ca.html初期:一.基本算法:(1)枚举. (poj1753,poj2965)(2)贪心(poj1328,poj2109,poj2586)(3)递归和分治法.(4)递推.(5)构造法.(poj3295)(6)模拟法.(poj1068,poj2632,poj1573,poj2993,poj2996)二.图算法:(1)图的深度优先遍历和广度优先遍历.(2)最短路径算法(dijkstra,bellman-ford,floyd,heap+dijkstra) (poj1860,poj3259, 阅读全文

posted @ 2013-06-11 23:07 KimKyeYu 阅读(700) 评论(0) 推荐(0) 编辑

EOJ-1014 BOX

摘要: poj 2160 http://poj.org/problem?id=2160eoj 1014 http://www.acm.cs.ecnu.edu.cn/problem.php?problemid=1014题意:给定6个矩形,判断能否组成一个盒子。简单的说一下思想:假设这个Box有6个面,那么长宽高分别是a、b、c。那么就有3个面的关系如下(一共六个面,但是相对的面相等):a * ba * cb * c这里假设 a >= b >= c我的想法是先输入,再按长边排序。如Sample 得到的就是2584 13452584 1345 //与上面的对称2584 6832584 683 / 阅读全文

posted @ 2013-06-11 23:01 KimKyeYu 阅读(177) 评论(0) 推荐(0) 编辑

poj 1836 Alignment

摘要: http://poj.org/problem?id=1836题意: 一队士兵排队,高低起伏。去掉最少的士兵,使得中间高两边低(单峰)。经典LIS,注意[1~n]的最优解并不一定在dp[n]中,故需预处理。 1 #include <iostream> 2 #include <stdio.h> 3 #include <string> 4 #include <string.h> 5 #include <stdlib.h> 6 #define EPS 1e-5 7 #define INF 0x3f3f3f 8 9 using namespac 阅读全文

posted @ 2013-06-11 16:31 KimKyeYu 阅读(165) 评论(0) 推荐(0) 编辑

2013年6月10日

poj 1862 Stripies

摘要: http://poj.org/problem?id=1862题意描述: 有n个生物,体重为w1, w2, ... , wn;任意两个生物可合成为一个生物;其体重w'满足:w' = 2sqrt(wi * wj); 如此反复,终将得到一个生物,体重为W。适当调整合成顺序,使得W最小。思路:贪心 每次取体重最大的两个生物先合成。证明: 不妨设w1>w2>...>wn, f(a, b) = 2sqrt(a*b); 那么按照贪心策略: W = f(f(... f(f(w1, w2), w3) ...), wn); (1)Hint:(1)式正确,是因为f(w1, w2)合 阅读全文

posted @ 2013-06-10 21:09 KimKyeYu 阅读(190) 评论(0) 推荐(0) 编辑

2013年6月9日

EOJ-2859 表达式的个数

摘要: http://acm.cs.ecnu.edu.cn/problem.php?problemid=2859简单dfs。但花了比较大的精力去处理不添加符号的情况,求出所有的情况复杂度大概是8*3^8,最后用map匹配完成dfs遍历时存下添加符号的方法,到最终再计算处理会比较清晰。用hash可能更快。 1 #include<map> 2 #include<cmath> 3 #include<queue> 4 #include<cctype> 5 #include<cstdio> 6 #include<string> 7 #inc 阅读全文

posted @ 2013-06-09 23:22 KimKyeYu 阅读(326) 评论(0) 推荐(0) 编辑

EOJ-2108 小强函数

摘要: 链接:http://www.acm.cs.ecnu.edu.cn/problem.php?problemid=2108题意是约瑟夫环问题的嵌套。由于这题的数据多大,导致不得不用公式法,设2^k<=n<2^(k+1),则题解为(n-2^k)+1这题由于n可以到2^63-1,所以在写函数的时候必须要用unsigned long long,不然会溢出 1 #include <iostream> 2 #include <cstdio> 3 #include <cstdlib> 4 #include <cstring> 5 #include & 阅读全文

posted @ 2013-06-09 14:51 KimKyeYu 阅读(256) 评论(0) 推荐(0) 编辑

EOJ 1046 4个数的和为0

摘要: poj 2785 http://poj.org/problem?id=2785eoj 1046 http://acm.cs.ecnu.edu.cn/problem.php?problemid=1046 思路: 散列(hash) + 拉链法去冲突; 具体过程: 把num[][1-4]按列划分为num[][1-2] 和 num[][3-4]; 对 MAXN + num[i][1] + num[j][2] 散列;O(n^2 * len) 对 MAXN - num[i][3] - num[j][4] 查找;O(n^2 * len) 须使得被散列值为正,故用一大数 MAXN 保护;len为链表平均... 阅读全文

posted @ 2013-06-09 13:38 KimKyeYu 阅读(205) 评论(0) 推荐(0) 编辑

【转】各大OJ题目分类

摘要: 原地址 http://blog.csdn.net/linleiqin/article/details/5637647-----------------------------最优化问题------------------------------------- ----------------------常规动态规划 SOJ1162 I-Keyboard SOJ2096 Maximum Submatrix SOJ2111 littleken bg SOJ2142 Cow Exhibition SOJ2505 The County Fair SOJ2818 QQ音速 SOJ2469 Explori 阅读全文

posted @ 2013-06-09 12:50 KimKyeYu 阅读(336) 评论(0) 推荐(0) 编辑

EOJ-2014 Sum of digits

摘要: 链接:http://www.acm.cs.ecnu.edu.cn/problem.php?problemid=2014题目的大意是指有多少个k位数组满足和的各位数之和等于各位数之和的和本质上就是在求有多少个k位数组满足求和时不进位,首位不可以有0,所以第一位有36种可能,之后后都有55种可能,所以k位数共36*55^(k-1)组,这个用乘法定理就可以证明,而且这题的数据很大,所以只能用高精度的算法实现 1 #include <iostream> 2 #include <cstdio> 3 #include <cstdlib> 4 #include <c 阅读全文

posted @ 2013-06-09 12:40 KimKyeYu 阅读(284) 评论(0) 推荐(0) 编辑

EOJ-2927 负载平衡问题

摘要: 链接:http://www.acm.cs.ecnu.edu.cn/problem.php?problemid=2927 这道题用了均分纸牌的方法 开始容易想到在所有的仓库中找到最多的库存量,然后向小的仓库移动,一直到所有的货物都相等,但关键是不知道往哪个方向上移动才能达到移动次数最少。设a[i]为第i个仓库的库存量(0<=i<=n),ave为均分后每个仓库的库存量,ans为最小移到次数。我们按照由左而右的顺序移动货物。若第i个仓库的库存量a[i]超出平均值,则移动一次(ans+1),将超出部分留给下一个仓库,既第i+1个仓库的库存量增加a[i]-ave;若第i个仓库的库存量a[i] 阅读全文

posted @ 2013-06-09 12:34 KimKyeYu 阅读(255) 评论(0) 推荐(0) 编辑

上一页 1 ··· 4 5 6 7 8

导航