NY 47 过河问题

过河问题

时间限制:1000 ms  |  内存限制:65535 KB

难度:5

描述

在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边。如果不借助手电筒的话,大家是无论如何也不敢过桥去的。不幸的是,N个人一共只带了一只手电筒,而桥窄得只够让两个人同时过。如果各自单独过桥的话,N人所需要的时间已知;而如果两人同时过桥,所需要的时间就是走得比较慢的那个人单独行动时所需的时间。问题是,如何设计一个方案,让这N人尽快过桥。

输入
第一行是一个整数T(1<=T<=20)表示测试数据的组数

每组测试数据的第一行是一个整数N(1<=N<=1000)表示共有N个人要过河

每组测试数据的第二行是N个整数Si,表示此人过河所需要花时间。(0<Si<=100)

输出
输出所有人都过河需要用的最少时间
样例输入
1
4
1 2 5 10
样例输出
17
来源
POJ

思路:

一般来说,我们一看到这个题,我们第一个想到的就是,让最快的和其他人一起过桥,然后最快的那个人来送电筒这个肯定是最快的,其实不一定,如果这样做肯定出错,因为题上给的数据就比你这样做的用时要少,那我们就又该好好想想,怎样才会更快呢?其实就是让前两个想对较快的两个人先过河,让最快的来送手电筒,然后让两个最慢的两个人一起过河,然后让第二快的来送手电筒,然后这两个快的再一起过河就正好是题上的答案,仔细想想,为什么会出现这样的现象呢?这就是因为第二个快的走的时间也比较短,而第二慢的走的时间比较长,所以才会造成这种现象!因为当你让后两个一起过河的话倒数第二个人的时间就不用算了,而得计算两次第二个人的时间,如果第二个人的时间的二倍也比倒数第二个人的小,那就选第二种,否则选第一种!当然又考虑到万一有5个,6个,7个等等人的话,我们该怎么办呢?很简单,我们以部分的最优来代替整体的最优,我们每次都用最短的时间将最慢的两个人送过河,然后将剩下的与4进行比较,如果大于4,继续只当成就4个人用最短的时间把最慢的两个送过河,如果小于4,则跳出循环,执行下面的if语句,if语句包括三种情况,第一种是n==3,这时让最慢的和最快的一起过河,然后最快的来送手电筒,然后再和第二快的一起过河就都过来河了;如果n==2;两个人一起过河;如果n==1,直接一个人过河就行了!(在小于等于3的时候只有这一种情况最省时间,所以不必判断了)

代码:

#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;

int cmp(int a,int b)//按照从小到大的顺序排序
{
	return a<b;
}

int main()
{
	int a[1005];
	int n,T,i,j,k,t;
	scanf("%d",&T);
	while(T--)
	{
		t=0;
		scanf("%d",&n);
		for(i=0;i<n;i++)//输入n个人各自所需要的时间
	    	scanf("%d",&a[i]);
	    sort(a,a+n,cmp);//对时间按照从小到大的顺序排序
	    while(n>=4)//每次都让用最短的时间把走路最慢的两个人送过岸
	    {
	    	if(2*a[0]+a[n-2]+a[n-1]<2*a[1]+a[0]+a[n-1])//因为不同的时间会出现两种最大值所以需要比较
	    		t += 2*a[0]+a[n-2]+a[n-1];
			else
				t += 2*a[1]+a[0]+a[n-1];
			n=n-2;
	    }
	    if(n==3)
			t+=a[0]+a[1]+a[2];
		else if(n==2)
			t+=a[1];
		else if(n==1)
			t+=a[0];
		printf("%d\n",t);
	}
	return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-28 20:17:54

NY 47 过河问题的相关文章

POJ-1700 &amp;&amp;NYOJ 47 过河问题【贪心】

链接:NYOJ:click here POJ:click here 题意: 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边.如果不借助手电筒的话,大家是无论如何也不敢过桥去的.不幸的是,N个人一共只带了一只手电筒,而桥窄得只够让两个人同时过.如果各自单独过桥的话,N人所需要的时间已知:而如果两人同时过桥,所需要的时间就是走得比较慢的那个人单独行动时所需的时间.问题是,如何设计一个方案,让这N人尽快过桥. 思路: 贪心思想(一般都是先排序) 每次从此岸到对岸移动的两个人要么这两个人中有一

nyist 47 过河问题

http://acm.nyist.net/JudgeOnline/problem.php?pid=47 过河问题 时间限制:1000 ms  |  内存限制:65535 KB 难度:5 描述 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边.如果不借助手电筒的话,大家是无论如何也不敢过桥去的.不幸的是,N个人一共只带了一只手电筒,而桥窄得只够让两个人同时过.如果各自单独过桥的话,N人所需要的时间已知:而如果两人同时过桥,所需要的时间就是走得比较慢的那个人单独行动时所需的时间.问题是,如何

nyoj 47 过河问题

过河问题 时间限制:1000 ms  |  内存限制:65535 KB 难度:5 描述 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边.如果不借助手电筒的话,大家是无论如何也不敢过桥去的.不幸的是,N个人一共只带了一只手电筒,而桥窄得只够让两个人同时过.如果各自单独过桥的话,N人所需要的时间已知:而如果两人同时过桥,所需要的时间就是走得比较慢的那个人单独行动时所需的时间.问题是,如何设计一个方案,让这N人尽快过桥. 输入 第一行是一个整数T(1<=T<=20)表示测试数据的组数每组测

nyoj 47 过河 过河问题 【贪心】

经典贪心: 两种方案:一:让最快的和次最快的先过去,最快的回来,然后最慢的和次最慢的过去,次最快的回来a[0]+a[1]+a[1]+a[n-1] 二:最快的和最慢的过去,最快的回来,最快的和当前最慢的过去,最快的回来.a[0]+a[n-1]+a[0]+a[n-2] 每次取最优解. 注意:最后剩余没过的人小于等于3的时候,要特殊判断. 代码: #include <cstdio> #include <cstring> #include <algorithm> #define

NYOJ-47过河问题

这是一道经典的贪心算法的题目.首先说一下我对这道题的理解: n个人要过河,已知每个人的过河时间且过河时必须要使用唯一的手电筒.桥只能允许最多 两个人同时过河.让求所有人都过河后的最短时间. 我们不难知道:必须同时两个人过河,因为要把手电筒送回来,让为过河的人过河.使用贪 心的思想解决这个问题,首先要对这n个人的过河时间排序并保存在数组S中.这也是大多数贪心 解决问题的共同点. 根据贪心原则,我们有两个贪心策略: 策略A: 让最快的两个人去送最慢的两个人.首先S[0]和S[1]过河,S[0]把手电

nyoj 47——过河问题——————【贪心】

过河问题 时间限制:1000 ms  |  内存限制:65535 KB 难度:5 描述 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边.如果不借助手电筒的话,大家是无论如何也不敢过桥去的.不幸的是,N个人一共只带了一只手电筒,而桥窄得只够让两个人同时过.如果各自单独过桥的话,N人所需要的时间已知:而如果两人同时过桥,所需要的时间就是走得比较慢的那个人单独行动时所需的时间.问题是,如何设计一个方案,让这N人尽快过桥. 输入 第一行是一个整数T(1<=T<=20)表示测试数据的组数每组测

NYOJ 47过河问题

主要思路:先排序.有两种可能是最小的情况,一种是让最小的去带着最大的过去,然后最小的再回来,还有一种就是先最小的和第二小的一块过去, 然后最小的回来,让最大的和第二大的过去,接着第二小的回来,第二小和最小的接着在过去,最小的接着回来,主要就是这两种,用的时候判断一下,接着的问题就是n是奇数还是偶数的问题 排完序之后的a[0]最小, a[n-1]最大,第一种的时间为a[0] + a[n -1] + a[0] + a[n - 2];其中a[0]是最短的时间,a[n-1]是最大的时间,下面一样, 第二

HDU 4770 Lights Against Dudely 暴力枚举+dfs

又一发吐血ac,,,再次明白了用函数(代码重用)和思路清晰的重要性. 11779687 2014-10-02 20:57:53 Accepted 4770 0MS 496K 2976 B G++ czy Lights Against Dudely Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 1360    Accepted Subm

1632: [Usaco2007 Feb]Lilypad Pond

1632: [Usaco2007 Feb]Lilypad Pond Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 404  Solved: 118[Submit][Status][Discuss] Description Farmer John 建造了一个美丽的池塘,用于让他的牛们审美和锻炼.这个长方形的池子被分割成了 M 行和 N 列( 1 ≤ M ≤ 30 ; 1 ≤ N ≤ 30 ) 正方形格子的 .某些格子上有惊人的坚固的莲花,还有一些岩石,