- poj3253
Ruiyang_061X
哈夫曼树。#include#includeusingnamespacestd;intN;priority_queue,greater>q;longlongres;intmain(){cin>>N;inta;while(N--){cin>>a;q.push(a);}intb,c;while(q.size()>=2){b=q.top();q.pop();c=q.top();q.pop();res+=b
- POJ 3253-Fence Repair(优先队列)
Rocky0429
STLPoj
题目地址:POJ3253题意:有一个农夫要把一个木板钜成n块给定长度的小木板,每次锯都要收取一定费用,这个费用就是当前锯的这个木版的长度,求最小费用。思路:每次将两个当前的最小值的和放入优先队列中,然后直到剩下一个数为止。#include#include#include#include#include#include#include#include#include#include#include#
- ACM-贪心入门:POJ3253 Fence Repair
三号室
贪心ACMACM贪心算法哈夫曼树最小堆
ACM-贪心入门:POJ3253FenceRepair中文题意输入输出示例输入示例输出解决思路AC代码为简化文章,原题请直接看原题链接中文题意给你一块长木板,其长度为L,要求将其切割成若干块指定大小的木板,大小分别为a,b,c,d…其中L恰好等于a+b+c+d+…,每切割一次,所需的花费为当前执行切割操作的木板的的长度。比如将长度为P的木板切割为K和H,则花费为P。求最小的花费的切割方法的所需花费
- poj3253
weixin_33915554
数据结构与算法
FenceRepairTimeLimit:2000MSMemoryLimit:65536KTotalSubmissions:10913Accepted:3459DescriptionFarmerJohnwantstorepairasmalllengthofthefencearoundthepasture.HemeasuresthefenceandfindsthatheneedsN(1≤N≤20,0
- POJ3253 Fence Repair (二叉堆 | 优先队列 | huffman树 )
svitter
————ACM————基础数据结构ACMfromVit
本文出自:http://blog.csdn.net/svitter题意:给你几根木板,让你连接起来,每次连接花费为两根长度之和。连接所有的木板,最后最小的花费是多少。输入输出分析:略。算法数据结构分析:这个题目用贪心即可。即,每次的取两根最小的,花费最少,最后花费就最少。本题目可以用二叉堆的最关键就在于二叉堆的定义:大根堆:上面的比下面的大;小根堆:上面的比下面的小;通过一维数组最后一个添加或者删
- POJ3253 Fence Repair(贪心,哈夫曼树)
oldwong77
描述:割木板,割木板的长度就是化的钱。比如你要885的木板,最简单的方式是把21的木板割成13,8,花费21,再把13割成5,8,花费13,共计34,当然也可以先割成16,5的木板,花费21,再把16割两个8,花费16,总计37,现在就是问你花费最少的情况。分析:贪心算法。每次选取最小的两个木板,拼接成新的长度,加入到木板队列中,直到队列中只有一块木板。需要注意的是:最终结果的长度可能超过int,
- POJ 3253 Fence Repair (哈夫曼编码基础)
Strokess
哈夫曼贪心
POJ3253用了哈夫曼编码的思想参考博客:http://blog.csdn.net/lyy289065406/article/details/6647423#include#include#include#include#includeusingnamespacestd;longlongL[20010];intmain(){intn;while(~scanf("%d",&n)){inti,j;f
- 贪心算法 POJ3253 Fence Repair
DTree123
OJ
题目大意:将一很长的木板切割成N块。每块长度分别为L1、L2、...、LN,每次切断木板时需要的开销为这块木板的长度。我的理解:这道题属于贪心算法类型,在做的时候要用到哈夫曼编码。代码:#include#include#include#defineMAX_N20000usingnamespacestd;/**哈夫曼树--贪心算法思想:对于最优解来讲,最短的板应当是深度最大的叶子节点之一*/type
- poj3253求切割木板开销最少是多少, 赫夫曼编码
&小鹏鹏
/*poj3252:农夫为修理栅栏,要将一块很长的木板切成N块,准备切成的木板的长度为L1,L2,L3……Ln。未切割木板之前的长度正好是是要切割的总长度。每次切断木板时,需要的开销为这块木板的长度,求出按照目标要求将木板切割完成最小的开销是多少。1#include#includeusingnamespacestd;#defineMAX_N20000typedeflonglongll;intN,L
- poj3253切割木板(哈夫曼树) 贪心【优先队列】
星琳之梦
POJ贪心挑战程序
FenceRepairTimeLimit:2000MSMemoryLimit:65536KTotalSubmissions:37272Accepted:12078DescriptionFarmerJohnwantstorepairasmalllengthofthefencearoundthepasture.HemeasuresthefenceandfindsthatheneedsN(1≤N≤20,
- poj3253
mwl46
acmacm
**##贪心法##**开始的思路是:1.N个数据排序2.将最小的两个数据相加的和与剩下的数据合在一起组成N-1个数据,并将最小的两个数据相加的和存储在res中。3.重复1,2直到剩下一个数据。但是出现了TimeLimitExceeded#include#include#defineMAX_N20000usingnamespacestd;intL[MAX_N],N;longlongans=0;voi
- poj3253 Fence Repair 贪心策略【挑战程序设计竞赛】
tobe_numberone
挑战程序设计竞赛
题目链接:http://poj.org/problem?id=3253FenceRepairTimeLimit:2000MSMemoryLimit:65536KTotalSubmissions:72299Accepted:23743DescriptionFarmerJohnwantstorepairasmalllengthofthefencearoundthepasture.Hemeasurest
- POJ3253解题报告
Moon_1st
题目的大致意思为:有一块长木板,要经过n-1次切割将其切成n块FJ想要的木板,对于每块木板,没切割一次,将会消耗和这条木板长度值相等的金钱,问最少需要多少钱,可将木板切成自己想要的n块。算法:题目看起来像是用DP来解,DP是可以解决,不过再看看数据量,哇塞nusingnamespacestd;longlongn,i,ans,p[20001];voidheap(longx,longy){longi,
- POJ 3253 (贪心算法+优先队列的基本用法)
季一
STL
参考https://www.jianshu.com/p/50f1d4e0555c贪心算法:1.动态规划的一种特殊情况。2.通过求局部最优解来获得整体最优解。3.使用贪心算法的前提是该问题具有最优子结构。4.通过可循环执行的语句实现。5.一般都为逆序思维常用于:1.一般背包问题2.活动安排问题3.最小生成树4.找零钱问题5.均分纸牌问题6.最大整数....实例:POJ3253木板切割问题题意:给定一
- 【POJ3253】Fence Repair(合并果子的翻版)
chenxiaoran666
堆POJ贪心
题面:【POJ3253】FenceRepair考虑到每一次切割所花费的代价是所切割的木板的长度,那我们就可以反向思考,合并两块木板所花费的代价是这两块木板的长度和,那么问题就转化为了将输入中给出的N块木板给两两合并在一起。于是,我们会惊奇地发现这道题其实就是合并果子的翻版,一道用小根堆来优化的贪心题!当然了,手打堆是比较麻烦的,相比之下,C++自带的优先队列就好用多了。代码见下:#include#
- POJ3253——Fence Repair
sdljtyk
贪心POJ
FenceRepairTimeLimit:2000MSMemoryLimit:65536KTotalSubmissions:45499Accepted:14850DescriptionFarmerJohnwantstorepairasmalllengthofthefencearoundthepasture.HemeasuresthefenceandfindsthatheneedsN(1≤N≤20,
- poj3253
sentimental_dog
挑战程序设计竞赛p47注意到木板的分割是一个二叉树,每个最后的Li都是一个叶子节点,所以实质上就是构造哈夫曼树。用快排和插入排序来构造了一个哈夫曼树。#include
#include
usingnamespacestd;
typedeflonglongLL;
intN;
constintmaxn=20005;
intL[maxn];
LLans;
voidInsert_Sort(intlo,in
- 哈夫曼树(POJ3253)
qq_27803491
哈夫曼树poj3253
题目POJ3253大概题意:XX想修补东西,然后需要用木板。可以认为XX有一根无限长(长度=他需要的木板长度总和)的木板,但是他需要N块长度为Li的木板,所以他需要把这块无限长的木板锯成他需要的。每次锯木板的花费与锯之前木板的长度相等。求最小花费!测试案例:385834sum=0;开始木板长度21(8+5+8),sum+=21,要锯成13+8;然后,需要锯的木板长度13,sum+=13,要锯成5+
- poj3253切割木板(哈夫曼树) 贪心【优先队列】
sinat_19628145
FenceRepairTimeLimit:2000MS MemoryLimit:65536KTotalSubmissions:37272 Accepted:12078DescriptionFarmerJohnwantstorepairasmalllengthofthefencearoundthepasture.HemeasuresthefenceandfindsthatheneedsN(1≤N≤2
- poj3253——哈夫曼树思想 + 优先队列解决
liujian20150808
哈夫曼树poj优先队列问题转换思想
题目链接:FenceRepair题目描述:FenceRepairTimeLimit: 2000MS MemoryLimit: 65536KTotalSubmissions: 37099 Accepted: 12013DescriptionFarmerJohnwantstorepairasmalllengthofthefencearoundthepasture.Hemeasuresthefencea
- POJ 3253 Fence Repair (哈夫曼编码基础)
Strokess
POJ3253用了哈夫曼编码的思想参考博客:http://blog.csdn.net/lyy289065406/article/details/6647423#include
#include
#include
#include
#include
usingnamespacestd;
longlongL[20010];
intmain(){
intn;
while(~scanf("%d",&n))
- poj3253
poj
/** \brief poj 3253
*
* \param date 2014/8/8
* \param state AC
* \return memory 1124K time 125ms
*
*/
#include <iostream>
#include <fstream>
#include <queue>
#include <func
- POJ3253 Fence Repair(贪心)
AIR
分割木板的顺序是自由的,所以每次选择两块最短的板,组合在一起,增加队列,原来两个板出队,直到队列中为空或者仅仅剩下一个板时结束。这里使用优先队列较为方便。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
- poj3253
poj
小根堆
#include <iostream>
#include <stdio.h>
#define M 20002
using namespace std;
int A[M],len;
void Min_Heap(int i)
{
int l=i<<1,r=l+1;
int temp,least=i;
if(l<=len&am
- POJ3253(Fence Repair)
AIR
题目链接
贪心题,也是训练优先队列的好题。
题目大意:给一块长木板,现要将其锯成n段,共需锯n-1次,每次锯的代价为所锯木板的长度,求最小总代价。
其实也可以看成是把n段木板拼成一块,每次拼的代价为所拼木板的长度和。这就跟哈夫曼编码一样,每次选取两个最小的来拼。具体实现时用优先队列。 View Code
1 #include <stdio.h>
2 #inclu
- POJ3253 Fence Repair ——贪心(Huffman树的构造)+堆——Pku3253
Huffman
思想与合并果子相同。逆序地来想,显然这些板子必须一共切割n-1次,如何恰当的分配这n-1次切割就是关键所在。这里就用到了构造Huffman树的贪心思想。
即每次从待合并序列中取两个最小的值,将它们合并成一个较大的,然后把这个较大的在加入进待合并的序列当中,直到待合并序列中只有一个元素。而不加任何优化时复杂度为O(n^2),难以承受。
可以用堆将复杂度优化到O(nlogn),就完全可以接受了。
- 二叉堆(一):基础
基础
原来对堆虽然理论比较了解但只打过几个堆排序,最近复习一下吧。
POJ3253
{
FJ要把一条木棒切成给定长度的n根木条,每次的花费是木棒的长度,求总花费
和合并果子基本一样,但是题目描述是逆向的,需要一点思考,可以把切割看成合并,贪心得合并最小的木条并记录最花费
虽然用队列是最优的,但就用来练习基本的heap操作吧,支持下滤,返回并删除最小元
2011-06-19 22:41
- POJ3253 Haffman
poj
POJ3253
分析:
简单的哈弗曼树的应用。
AC代码:
1 //Memory: 316K Time: 16MS
2 #include <iostream>
3 #include <cstring>
4 #include <cstdio>
5 #include <queue>
6
7 using
- poj3253
poj
Fence Repair
Time Limit: 2000MS
Memory Limit: 65536K
Total Submissions: 10913
Accepted: 3459
Description
Farmer John wants to repair a small length of the fence
- 优先队列/POJ3253,哈夫曼树(求最小木板分割费用)
哈夫曼树
描述:一个需要 9 10 11三块木板,现在他有9+10+11长度的木板,但是分割L长度的木板费用就是L,因此求怎么分割费用最小
算法:构造哈夫曼树,队列中取出最小的两个数放在底层,它们的和入队,如此反复;可以利用优先队列priority_queue
优先队列priority_queue默认大的数先出队,因此需要重载小于号
Sample Input
3
8
- html页面js获取参数值
0624chenhong
html
1.js获取参数值js
function GetQueryString(name)
{
var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
var r = windo
- MongoDB 在多线程高并发下的问题
BigCat2013
mongodbDB高并发重复数据
最近项目用到 MongoDB , 主要是一些读取数据及改状态位的操作. 因为是结合了最近流行的 Storm进行大数据的分析处理,并将分析结果插入Vertica数据库,所以在多线程高并发的情境下, 会发现 Vertica 数据库中有部分重复的数据. 这到底是什么原因导致的呢?笔者开始也是一筹莫 展,重复去看 MongoDB 的 API , 终于有了新发现 :
com.mongodb.DB 这个类有
- c++ 用类模版实现链表(c++语言程序设计第四版示例代码)
CrazyMizzz
数据结构C++
#include<iostream>
#include<cassert>
using namespace std;
template<class T>
class Node
{
private:
Node<T> * next;
public:
T data;
- 最近情况
麦田的设计者
感慨考试生活
在五月黄梅天的岁月里,一年两次的软考又要开始了。到目前为止,我已经考了多达三次的软考,最后的结果就是通过了初级考试(程序员)。人啊,就是不满足,考了初级就希望考中级,于是,这学期我就报考了中级,明天就要考试。感觉机会不大,期待奇迹发生吧。这个学期忙于练车,写项目,反正最后是一团糟。后天还要考试科目二。这个星期真的是很艰难的一周,希望能快点度过。
- linux系统中用pkill踢出在线登录用户
被触发
linux
由于linux服务器允许多用户登录,公司很多人知道密码,工作造成一定的障碍所以需要有时踢出指定的用户
1/#who 查出当前有那些终端登录(用 w 命令更详细)
# who
root pts/0 2010-10-28 09:36 (192
- 仿QQ聊天第二版
肆无忌惮_
qq
在第一版之上的改进内容:
第一版链接:
http://479001499.iteye.com/admin/blogs/2100893
用map存起来号码对应的聊天窗口对象,解决私聊的时候所有消息发到一个窗口的问题.
增加ViewInfo类,这个是信息预览的窗口,如果是自己的信息,则可以进行编辑.
信息修改后上传至服务器再告诉所有用户,自己的窗口
- java读取配置文件
知了ing
1,java读取.properties配置文件
InputStream in;
try {
in = test.class.getClassLoader().getResourceAsStream("config/ipnetOracle.properties");//配置文件的路径
Properties p = new Properties()
- __attribute__ 你知多少?
矮蛋蛋
C++gcc
原文地址:
http://www.cnblogs.com/astwish/p/3460618.html
GNU C 的一大特色就是__attribute__ 机制。__attribute__ 可以设置函数属性(Function Attribute )、变量属性(Variable Attribute )和类型属性(Type Attribute )。
__attribute__ 书写特征是:
- jsoup使用笔记
alleni123
java爬虫JSoup
<dependency>
<groupId>org.jsoup</groupId>
<artifactId>jsoup</artifactId>
<version>1.7.3</version>
</dependency>
2014/08/28
今天遇到这种形式,
- JAVA中的集合 Collectio 和Map的简单使用及方法
百合不是茶
listmapset
List ,set ,map的使用方法和区别
java容器类类库的用途是保存对象,并将其分为两个概念:
Collection集合:一个独立的序列,这些序列都服从一条或多条规则;List必须按顺序保存元素 ,set不能重复元素;Queue按照排队规则来确定对象产生的顺序(通常与他们被插入的
- 杀LINUX的JOB进程
bijian1013
linuxunix
今天发现数据库一个JOB一直在执行,都执行了好几个小时还在执行,所以想办法给删除掉
系统环境:
ORACLE 10G
Linux操作系统
操作步骤如下:
第一步.查询出来那个job在运行,找个对应的SID字段
select * from dba_jobs_running--找到job对应的sid
&n
- Spring AOP详解
bijian1013
javaspringAOP
最近项目中遇到了以下几点需求,仔细思考之后,觉得采用AOP来解决。一方面是为了以更加灵活的方式来解决问题,另一方面是借此机会深入学习Spring AOP相关的内容。例如,以下需求不用AOP肯定也能解决,至于是否牵强附会,仁者见仁智者见智。
1.对部分函数的调用进行日志记录,用于观察特定问题在运行过程中的函数调用
- [Gson六]Gson类型适配器(TypeAdapter)
bit1129
Adapter
TypeAdapter的使用动机
Gson在序列化和反序列化时,默认情况下,是按照POJO类的字段属性名和JSON串键进行一一映射匹配,然后把JSON串的键对应的值转换成POJO相同字段对应的值,反之亦然,在这个过程中有一个JSON串Key对应的Value和对象之间如何转换(序列化/反序列化)的问题。
以Date为例,在序列化和反序列化时,Gson默认使用java.
- 【spark八十七】给定Driver Program, 如何判断哪些代码在Driver运行,哪些代码在Worker上执行
bit1129
driver
Driver Program是用户编写的提交给Spark集群执行的application,它包含两部分
作为驱动: Driver与Master、Worker协作完成application进程的启动、DAG划分、计算任务封装、计算任务分发到各个计算节点(Worker)、计算资源的分配等。
计算逻辑本身,当计算任务在Worker执行时,执行计算逻辑完成application的计算任务
- nginx 经验总结
ronin47
nginx 总结
深感nginx的强大,只学了皮毛,把学下的记录。
获取Header 信息,一般是以$http_XX(XX是小写)
获取body,通过接口,再展开,根据K取V
获取uri,以$arg_XX
&n
- 轩辕互动-1.求三个整数中第二大的数2.整型数组的平衡点
bylijinnan
数组
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class ExoWeb {
public static void main(String[] args) {
ExoWeb ew=new ExoWeb();
System.out.pri
- Netty源码学习-Java-NIO-Reactor
bylijinnan
java多线程netty
Netty里面采用了NIO-based Reactor Pattern
了解这个模式对学习Netty非常有帮助
参考以下两篇文章:
http://jeewanthad.blogspot.com/2013/02/reactor-pattern-explained-part-1.html
http://gee.cs.oswego.edu/dl/cpjslides/nio.pdf
- AOP通俗理解
cngolon
springAOP
1.我所知道的aop 初看aop,上来就是一大堆术语,而且还有个拉风的名字,面向切面编程,都说是OOP的一种有益补充等等。一下子让你不知所措,心想着:怪不得很多人都和 我说aop多难多难。当我看进去以后,我才发现:它就是一些java基础上的朴实无华的应用,包括ioc,包括许许多多这样的名词,都是万变不离其宗而 已。 2.为什么用aop&nb
- cursor variable 实例
ctrain
variable
create or replace procedure proc_test01
as
type emp_row is record(
empno emp.empno%type,
ename emp.ename%type,
job emp.job%type,
mgr emp.mgr%type,
hiberdate emp.hiredate%type,
sal emp.sal%t
- shell报bash: service: command not found解决方法
daizj
linuxshellservicejps
今天在执行一个脚本时,本来是想在脚本中启动hdfs和hive等程序,可以在执行到service hive-server start等启动服务的命令时会报错,最终解决方法记录一下:
脚本报错如下:
./olap_quick_intall.sh: line 57: service: command not found
./olap_quick_intall.sh: line 59
- 40个迹象表明你还是PHP菜鸟
dcj3sjt126com
设计模式PHP正则表达式oop
你是PHP菜鸟,如果你:1. 不会利用如phpDoc 这样的工具来恰当地注释你的代码2. 对优秀的集成开发环境如Zend Studio 或Eclipse PDT 视而不见3. 从未用过任何形式的版本控制系统,如Subclipse4. 不采用某种编码与命名标准 ,以及通用约定,不能在项目开发周期里贯彻落实5. 不使用统一开发方式6. 不转换(或)也不验证某些输入或SQL查询串(译注:参考PHP相关函
- Android逐帧动画的实现
dcj3sjt126com
android
一、代码实现:
private ImageView iv;
private AnimationDrawable ad;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout
- java远程调用linux的命令或者脚本
eksliang
linuxganymed-ssh2
转载请出自出处:
http://eksliang.iteye.com/blog/2105862
Java通过SSH2协议执行远程Shell脚本(ganymed-ssh2-build210.jar)
使用步骤如下:
1.导包
官网下载:
http://www.ganymed.ethz.ch/ssh2/
ma
- adb端口被占用问题
gqdy365
adb
最近重新安装的电脑,配置了新环境,老是出现:
adb server is out of date. killing...
ADB server didn't ACK
* failed to start daemon *
百度了一下,说是端口被占用,我开个eclipse,然后打开cmd,就提示这个,很烦人。
一个比较彻底的解决办法就是修改
- ASP.NET使用FileUpload上传文件
hvt
.netC#hovertreeasp.netwebform
前台代码:
<asp:FileUpload ID="fuKeleyi" runat="server" />
<asp:Button ID="BtnUp" runat="server" onclick="BtnUp_Click" Text="上 传" />
- 代码之谜(四)- 浮点数(从惊讶到思考)
justjavac
浮点数精度代码之谜IEEE
在『代码之谜』系列的前几篇文章中,很多次出现了浮点数。 浮点数在很多编程语言中被称为简单数据类型,其实,浮点数比起那些复杂数据类型(比如字符串)来说, 一点都不简单。
单单是说明 IEEE浮点数 就可以写一本书了,我将用几篇博文来简单的说说我所理解的浮点数,算是抛砖引玉吧。 一次面试
记得多年前我招聘 Java 程序员时的一次关于浮点数、二分法、编码的面试, 多年以后,他已经称为了一名很出色的
- 数据结构随记_1
lx.asymmetric
数据结构笔记
第一章
1.数据结构包括数据的
逻辑结构、数据的物理/存储结构和数据的逻辑关系这三个方面的内容。 2.数据的存储结构可用四种基本的存储方法表示,它们分别是
顺序存储、链式存储 、索引存储 和 散列存储。 3.数据运算最常用的有五种,分别是
查找/检索、排序、插入、删除、修改。 4.算法主要有以下五个特性:
输入、输出、可行性、确定性和有穷性。 5.算法分析的
- linux的会话和进程组
网络接口
linux
会话: 一个或多个进程组。起于用户登录,终止于用户退出。此期间所有进程都属于这个会话期。会话首进程:调用setsid创建会话的进程1.规定组长进程不能调用setsid,因为调用setsid后,调用进程会成为新的进程组的组长进程.如何保证? 先调用fork,然后终止父进程,此时由于子进程的进程组ID为父进程的进程组ID,而子进程的ID是重新分配的,所以保证子进程不会是进程组长,从而子进程可以调用se
- 二维数组 元素的连续求解
1140566087
二维数组ACM
import java.util.HashMap;
public class Title {
public static void main(String[] args){
f();
}
// 二位数组的应用
//12、二维数组中,哪一行或哪一列的连续存放的0的个数最多,是几个0。注意,是“连续”。
public static void f(){
- 也谈什么时候Java比C++快
windshome
javaC++
刚打开iteye就看到这个标题“Java什么时候比C++快”,觉得很好笑。
你要比,就比同等水平的基础上的相比,笨蛋写得C代码和C++代码,去和高手写的Java代码比效率,有什么意义呢?
我是写密码算法的,深刻知道算法C和C++实现和Java实现之间的效率差,甚至也比对过C代码和汇编代码的效率差,计算机是个死的东西,再怎么优化,Java也就是和C