BridgeOverARoughRiver(POJ-3404)【AdHoc】
题目链接:https://vjudge.net/problem/POJ-3404
题意:n个极限速度不同的人要过桥,一开始所有人在桥的一边,每次最多两个人同时过桥,过桥时需要用一把火炬并且全场只有一把火炬,问所有人到达桥的另外一边所需最短时间。
思路:凭直觉很多人都会立刻想到每次都让最快的人在桥两边来回陪同其他人过桥,但是当遇到类似于1 2 10 11,这种,最优解为 1 2,1,10 11,2,1 2,并不是1 2,1,1 10,1,1 11.
设a最快,b次快,d次慢,c最慢,每次有两种策略可供选择(剩余人数大于等于4,其他情况很容易计算):
1.a b,a,c d,b,
2.a d,a,a c,a.
每次对两种方案进行比较即可。
代码如下:
#include<cstdio>
#include<list>
#include<iostream>
#include<algorithm>
using namespace std;
int main(){
list<int> lt;
int n,val[];
scanf("%d",&n);
for(int i=;i<=n;i++){
scanf("%d",&val[i]);
}
sort(val+,val++n);
for(int i=;i<=n;i++)
lt.push_back(val[i]);
list<int>::iterator it;
int ans=;
while(lt.size()>){
if(lt.size()>=){
int a=*lt.begin(),b,c,d;
it=lt.begin();it++;
b=*it;
it=lt.end();
it--;d=*it;
it--;c=*it;
int t1=b+a+d+b,t2=d+a+c+a;
ans+=min(t1,t2);
it=lt.end();
it--;lt.erase(it);
it=lt.end();it--;lt.erase(it);
}
else if(lt.size()==){
int a,b,c;
it=lt.begin();
a=*it;it++;
b=*it;it++;
c=*it;
int t=b+a+c;
ans+=t;
break;
}
else if(lt.size()==){
it=lt.begin();it++;
ans+=*it;break;
}
else {
ans+=*lt.begin();
break;
}
}
printf("%d",ans);
return ;
}
BridgeOverARoughRiver(POJ-3404)【AdHoc】的更多相关文章
- 【简●解】POJ 1845 【Sumdiv】
		
POJ 1845 [Sumdiv] [题目大意] 给定\(A\)和\(B\),求\(A^B\)的所有约数之和,对\(9901\)取模. (对于全部数据,\(0<= A <= B <= ...
 - POJ 2154 【POLYA】【欧拉】
		
前记: TM终于决定以后干啥了.这几天睡的有点多.困饿交加之间喝了好多水.可能是灌脑了. 切记两件事: 1.安心当单身狗 2.顺心码代码 题意: 给你N种颜色的珠子,串一串长度问N的项链,要求旋转之后 ...
 - POJ 3230 【DP】
		
题意: 某货旅行,在n个城市呆m天. 给出从第i个城市到第j个城市的路费,或者留在某个城市的生活费. 给出在第i天在第j个城市的收益. 可以在城市之间任意穿梭逗留没有其他特殊要求. 求收益最大是多少. ...
 - POJ 3187【permutation】
		
POJ 3187 给定N值,从而确定了数据的范围及长度,暴力枚举数列,接下来类似杨辉三角的递推计算.注permutation从递增有序数列开始枚举,枚举到符合sum值时退出即可 #include &l ...
 - POJ 2718【permutation】
		
POJ 2718 问题描述: 给一串数,求划分后一个子集以某种排列构成一个数,余下数以某种排列构成另一个数,求这两个数最小的差,注意0开头的处理. 超时问题:一开始是得到一个数列的组合之后再从中间进行 ...
 - Tiling POJ 2506 【大数】
		
id=2506">http://poj.org/problem?id=2506 Description In how many ways can you tile a 2xn rect ...
 - poj 2431 【优先队列】
		
poj 2431 Description A group of cows grabbed a truck and ventured on an expedition deep into the jun ...
 - poj 2385【动态规划】
		
poj 2385 Apple Catching Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14007 Accepte ...
 - POJ 1286 【POLYA】
		
题意: 给你三种颜色的珠子,每次给你N,问在旋转,翻转之后视作相同的情况下,能组成多少种不同的项链. 思路: 让我们借这道题拯救一下我对POLYA定理的理解... sigma(m^(gcd(i,n)) ...
 
随机推荐
- 北大ACM - POJ试题分类(转自EXP)
			
北大ACM - POJ试题分类 -- By EXP 2017-12-03 转载请注明出处: by EXP http://exp-blog.com/2018/06/28/pid-38/ 相关推荐文: 旧 ...
 - Python3操作YAML文件
			
数据及配置文件之争 数据及文件通常有三种类型: 配置文件型:如ini,conf,properties文件,适合存储简单变量和配置项,最多支持两层,不适合存储多层嵌套数据 表格矩阵型:如csv,exce ...
 - MySQL数据分析-(2)数据库的底层逻辑
			
(一) 数据库存在的逻辑 1.案例开篇-大部分公司对于数据和数字的管理都是低效率的 我们要学习数据库,就必须要搞清楚数据库是在什么样的情景下发明并流行的?学习新知识就要搞清楚每个知识点的来龙去脉,这样 ...
 - pwn学习日记Day8 基础知识积累
			
知识杂项 aslr:是一种针对缓冲区溢出的安全保护技术,通过对堆.栈.共享库映射等线性区布局的随机化,通过增加攻击者预测目的地址的难度,防止攻击者直接定位攻击代码位置,达到阻止溢出攻击的目的的一种技术 ...
 - UML期末复习题
			
看了网上的各种UML图的相关资料,找到的都是差不多一样的对图的基本介绍.之前复习的时候也想对不同UML图单独进行复习总结,后来发现这样复习好像没什么用,不能理解每个图之间的关系,所以就没有进一步总结. ...
 - 如何查看linux内核中驱动的初始化顺序?
			
答:通过生成的System.map可以查看到,主要关注__initcall_<module_entry_function>_init<level>,如: __initcall_ ...
 - linux shell中如何让$就表示为$呢?
			
答: 在$前加转义符\ 如: \$
 - Android Popwindow使用总结
			
Android Popwindow使用总结 转 https://www.jianshu.com/p/3812ff5ef272 1.基本使用方法 View view = getLayoutInflate ...
 - go协程理解
			
一.Golang 线程和协程的区别 备注:需要区分进程.线程(内核级线程).协程(用户级线程)三个概念. 进程.线程 和 协程 之间概念的区别 对于 进程.线程,都是有内核进行调度,有 CPU 时间片 ...
 - 一篇文章搞懂Python装饰器所有用法
			
01. 装饰器语法糖 如果你接触 Python 有一段时间了的话,想必你对 @ 符号一定不陌生了,没错 @ 符号就是装饰器的语法糖. 它放在一个函数开始定义的地方,它就像一顶帽子一样戴在这个函数的头上 ...