HDU 4883 Best Coder Round 2 TIANKENG’s restaurant 解读

HDU 4883 Best Coder Round 2 TIANKENG’s restaurant 解读

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

有一组数据是在客人到达和出发时间,问:多少把椅子的能力,以满足所有客人的需求,可以有一个地方坐下要求。

有些人甚至开始考虑暴力法,这些数据是少,其实这个问题很多数据, 暴力需求O(n*n)的时间效率,显然,将加班,因此,有必要O(n) 或O(nlgn)算法。

属于一道想透了就很easy的,可是没想过就会很困难的题目。

解法是:

把全部客人到来和离开的时间都排成序列。每次客人到来须要n张桌椅,那么就+上n,每次客人离开就会返还n张桌椅,那么就-去n,求这种最大值。

详细算法代码就那么几行,处理IO的代码都比这个长。

要想出来还真是十分困难。只是也算是经典算法了,应该学熟练。

const int MAX_N = 10001;
struct Interval
{
	int t, wei;
	bool operator<(Interval const &i) const
	{
		if (t == i.t) return wei < i.wei;
		return t < i.t;
	}
};

Interval inter[MAX_N<<1];

inline int timeToSec(int h, int m)
{
	return h * 60 + m;
}

int main()
{
	int T, n, h, m, w, num;
	scanf("%d", &T);
	while (T--)
	{
		scanf("%d", &n);
		num = 0;
		for (int i = 0; i < n; i++)
		{
			scanf("%d %d:%d", &w, &h, &m);
			inter[num].t = timeToSec(h, m);
			inter[num++].wei = w;

			scanf("%d:%d", &h, &m);
			inter[num].t = timeToSec(h, m);
			inter[num++].wei = -w;
		}
		sort(inter, inter+num);
		int ans = 0, tmp = 0;
		for (int i = 0; i < num; i++)
		{
			tmp += inter[i].wei;
			ans = max(tmp, ans);
		}
		printf("%d\n", ans);
	}
	return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117755.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux20个常用命令_常用shell命令

    linux20个常用命令_常用shell命令文章目录Linux_day01ipv4地址服务器Linux_day02Linux的文件目录Linux基本指令一.基础指令1.ls指令:2.pwd命令3.cd命令——改变目录4.mkdir—— 创建目录5.touch指令——创建文件6.cp指令——复制7.mv指令——移动,重命名8.rm指令——移除,删除9.vim指令10.输出重定向11.cat指令二.进阶指令1.df指令——查看磁盘空间2.free指令——查看当前内存的使用情况3.head指令——查看文件的前n行(默认n为10)4.tail指令——查看文件

    2022年8月9日
    4
  • WebGame开发过程中的一些思考和总结

    WebGame开发过程中的一些思考和总结WebGame如今已经很火,市场也很大,盛大和腾讯都已经看中这一块市场。我自己也在做这方面的研发,总结和思考一些问题。

    2022年5月29日
    29
  • 在idea中创建web项目_idea部署web项目

    在idea中创建web项目_idea部署web项目前言:很高兴能够用自己所学知识为你提供答疑!!!今天我就来操作下如何使用idea这款软件创建web项目。步骤:1.创建项目首先新建一个项目然后选择最后一个,创建一个空白的Java项目,点击Next。这个时候给项目命名,我在这里命名为java_web,下面那个可以更改项目存放的路径,我这里放到自定的路径,点击Finish。刚进来的时候,idea会提醒你是否新建一个模块,先点击×,一会我们再创建模块。2.配置jdk这个时候,我们先来配置jdk的路径,以及tomcat的路径,方便之后

    2022年4月19日
    68
  • 巴什博弈

    巴什博弈

    2021年9月2日
    94
  • Win10禁止更新小插件Privatezilla Version 0.50.5[通俗易懂]

    Win10禁止更新小插件Privatezilla Version 0.50.5[通俗易懂]Win10禁止更新小插件PrivatezillaVersion0.50.5禁用功能:Win10隐私、微软小娜、Bloatware、软件权限、Win更新等下载地址:https://l13144.lanzoui.com/iMdzkt5dr0j

    2022年5月4日
    141
  • ADB命令安装APK常见错误总结「建议收藏」

    ADB命令安装APK常见错误总结「建议收藏」通过adb命令安装应用过程:常见问题以及原因:Failure[INSTALL_FAILED_ALREADY_EXISTS]:应用已经存在,需要卸载设备中现有的。:没有找到设备,查看是否开启调试,或者数据线有问题Failure[INSTALL_FAILED_UPDATE_INCOMPATIBLE]:版本不能共存,可能使用了相同版…

    2022年6月8日
    64

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号