题意:

      题意最蛋疼,其实是水题,这个题意整的我wa了一个多小时,我就改改题意吧..有一条河,刚开始的时候在左岸有一条船,这条船最多能运n个货物,一趟的时间是t,有m个货物,每个货物有自己到达岸边的时间,你的任务就是输出所有货物到达对岸的那一刻的时间..只有当两岸有人船就会动,否则不会动..

思路:

     水模拟,这个题目别想多了,我们把自己当成是开船的就能知道怎么敲了,首先我们把左岸的存在一个数组里,右岸的存在一个数组里,循环的条件是(l <= n_l || r <= n_r),就是只要有人就循环,想想如果我们是开船人,每一步我们肯定是 那个岸的人来的早我们就开往哪个岸了,当时有一点要注意,就是假如当前我们在左岸,而右岸的那个比左岸早,那么我们肯定是要去右岸的,而我们什么间才能到右岸呢? 是右岸
node[r]? 还是 node[r] + t ?,其实都不是,而是time =  maxx(now_time + t ,node[r] + t);因为最快的时间是 node[r] + t,因为你是看见后才过去的,但是如果那个人是在你干活的时候来的,那么node[r] + t的时候你肯定赶不过去,所以取大的,还有就是虽然已经决定去右岸了,到达右岸的时间是上面的那个time,但我们如果在去之前,也就是time - t之前能在左岸拉几个货物我们肯定是拉着啊,反正题目说了,装卸货物时间0,那么不正白不正啊,所以把左岸能捡的就拉了就行了..就这样遍历到最后就行了.还有就是出题的那个货行不行了,题意说的神我本来就够蛋疼的了,测试数据之间输出换行能不能说下啊,整的老子各种wa之后又pe了一次..上面是个人见解,有错误望大牛支出..


#include<stdio.h>
#include<string.h> #define N 10000 + 50
int node_l[N] ,node_r[N];
int
id_l[N] ,id_r[N];
int
ans[N];
int
n_l ,n_r; int maxx(int x ,int y)
{
return
x > y ? x : y;
} int main ()
{
int
n ,y ,m ,tt ,t;
int
i ,j ,time;
char
str[10];
scanf("%d" ,&tt);
while(
tt--)
{

scanf("%d %d %d" ,&n ,&t ,&m);
n_l = n_r = 0;
for(
i = 1 ;i <= m; i ++)
{

scanf("%d %s" ,&time ,str);
if(
str[0] == 'l')
{

node_l[++n_l] = time;
id_l[n_l] = i;
}
else
{

node_r[++n_r] = time;
id_r[n_r] = i;
}
}
int
now_fx = 1 ,now_time = 0;
int
l = 1 ,r = 1;
while(
l <= n_l || r <= n_r)
{
if(
l <= n_l && node_l[l] < node_r[r] || r > n_r)
{ if(
now_fx != 1) now_time = maxx(now_time + t,node_l[l] + t);
else
now_time = maxx(now_time ,node_l[l]); if(now_fx != 1)
{
for(
i = 1 ;i <= n && r <= n_r;i ++)
{
if(
node_r[r] <= now_time - t)
{

ans[id_r[r++]] =now_time;
}
else break;
}
} for(
i = 1 ;i <= n && l <= n_l ;i ++)
{
if(
node_l[l] <= now_time)
{

ans[id_l[l++]] =now_time + t;
}
else break;
}

now_fx = 2;
now_time += t;
}
else
{
if(
now_fx != 2) now_time = maxx(now_time + t,node_r[r] + t);
else
now_time = maxx(now_time ,node_r[r]); if(now_fx != 2)
{
for(
i = 1 ;i <= n && l <= n_l;i ++)
{
if(
node_l[l] <= now_time - t)
{

ans[id_l[l++]] =now_time;
}
else break;
}
} for(
i = 1 ;i <= n && r <= n_r;i ++)
{
if(
node_r[r] <= now_time)
{

ans[id_r[r++]] =now_time + t;
}
else break;
}

now_fx = 1;
now_time += t;
}
}
for(
i = 1 ;i <= m ;i ++)
printf("%d\n" ,ans[i]);
if(
tt) printf("\n");
}
return
0;
}

hdu1146的更多相关文章

  1. Ferry Loading III[HDU1146]

    Ferry Loading IIITime Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...

随机推荐

  1. HDU1067 Gap

    题目: Let's play a card game called Gap. You have 28 cards labeled with two-digit numbers. The first d ...

  2. DRF(django rest-framework)

    1.什么是DRF django组件,快速帮助我们开发遵循restful规范的一个组件 2.什么是restful规范 RESTful的URL用于指定资源,URL中只能使用名词的组合来标识资源," ...

  3. Selenium 4.0beta:读源码学习新功能

    Selenium 4 源码分析 这一篇文章我们来分析Selenium 4 python版源码. 除非你对Selenium 3的源码烂熟于心,否则通过对比工具分析更容易看出Selenium 4更新了哪些 ...

  4. P2261 [CQOI2007]余数求和 【整除分块】

    一.题面 P2261 [CQOI2007]余数求和 二.分析 参考文章:click here 对于整除分块,最重要的是弄清楚怎样求的分得的每个块的范围. 假设$ n = 10 ,k = 5 $ $$  ...

  5. IDApro 快捷键

    https://www.hex-rays.com/wp-content/static/products/ida/idapro_cheatsheet.html File Operations Parse ...

  6. CentOS离线安装Nginx

    在医院搭建项目环境时,因为医院通常都是内网的,访问不了外网,所以很多服务都得通过离线的方式安装,下面讲讲CentOs系统中如何离线安装Nginx. 安装准备 Nginx离线安装依赖gcc.g++环境, ...

  7. 一次 outline 去除经验(非继承属性,看着像继承)

    情况描述: 目前维护的老项目是通过 easyui 生成的 html,嵌套结构非常多,当点击元素后,会有个边框???非常影响页面美观,这是啥迷惑点击交互??? 经验告诉我,这是 css 的 outlin ...

  8. Elasticsearch集群升级指引

    目录 背景 第一部分 版本升级指引 第二部分 升级方法和具体步骤 总结 参考文献及资料 背景 Elasticsearch集群的版本升级是一项重要的集群维护工作.本篇文章参考官方文档,将详细介绍相关细节 ...

  9. 面试准备——计算机网络(TCP的三次握手和四次挥手)

    一.TCP的报文结构 红色圈标出的是在讨论三次握手和四次挥手时会用到的首部字段: 顺序号(seq):TCP对从网络层传下来的数据报文进行分组,分成一段一段的TCP报文段,并对这些报文段进行编号.seq ...

  10. C#中SQLite的使用及工具类

    目录 SQLite简介 存储类 亲和类型 引用System.Data.SQLite.dll 软件包分类 使用本机库预加载 常用部署包 工具类 参考资料 SQLite简介 SQLite是一款轻型的数据库 ...