题意:

      题意最蛋疼,其实是水题,这个题意整的我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. 理解ASP.NET Core 中的WebSocket

    在本文中,我们将详细介绍RFC 6455 WebSocket规范,并配置一个通用的.NET 5应用程序通过WebSocket连接与SignalR通信. 我们将深入底层的概念,以理解底层发生了什么. 关 ...

  2. HDOJ-1301(最小生成树模板+Prim算法)

    Jungle Roads HDOJ-1301 这是最小生成树的水题,唯一要注意的就是那个n,其实输入只有n-1行. #include<iostream> #include<cstdi ...

  3. redhat安装python3.7

    下载并解压: 1 wget https://www.python.org/ftp/python/3.7.2/Python-3.7.2.tgz 2 tar -xzvf Python-3.7.2.tgz ...

  4. FTP操作/Passive/Active控制

    1 using System; 2 using System.Collections.Generic; 3 using System.Text; 4 using System.IO; 5 using ...

  5. MySQL在线DDL工具 gh-ost

    一.简介 gh-ost基于 golang 语言,是 github 开源的一个 DDL 工具,是 GitHub's Online Schema Transmogrifier/Transfigurator ...

  6. HOOK实现游戏无敌-直接修改客户端-2-使用VS来处理

    HOOK实现游戏无敌-直接修改客户端-2-使用VS来处理 大概流程 1 首先找到游戏进程,打开进程 2 申请一段内存空间来保存我们的硬编码(virtualAllocEx) 3 找到攻击函数,修改函数的 ...

  7. 使用C# (.NET Core) 实现命令设计模式 (Command Pattern)

    本文的概念内容来自深入浅出设计模式一书. 项目需求 有这样一个可编程的新型遥控器, 它有7个可编程插槽, 每个插槽可连接不同的家用电器设备. 每个插槽对应两个按钮: 开, 关(ON, OFF). 此外 ...

  8. Java进阶专题(二十七) 将近2万字的Dubbo原理解析,彻底搞懂dubbo (下)

    ...接上文 服务发现 服务发现流程 整体duubo的服务消费原理 Dubbo 框架做服务消费也分为两大部分 , 第一步通过持有远程服务实例生成Invoker,这个Invoker 在客户端是核心的远程 ...

  9. Detach blobs with a contact point

    https://answers.opencv.org/question/87583/detach-blobs-with-a-contact-point/ 一.问题描述 带有接触点的斑点时遇到问题,需要 ...

  10. 前端vue性能优化

    一:代码层次优化 1.1.v-if 和 v-show 区分使用场景 v-if 是 真正 的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建:也是惰性的:如果在初始渲染时 ...