题意:

      题意最蛋疼,其实是水题,这个题意整的我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. (三)String、StringBuilder、StringBuffer在字符串操作中的性能差异浅析

    参考资料:https://www.iteye.com/blog/hank4ever-581463 <Core Java Volume I-Fundamentals>原书第十版 <Ja ...

  2. 2.1 Python3基础-内置函数(print&input)

    >>返回主目录 源代码 # 内置函数:输入/输出 name = 'Portos' age = 18 sex = 'man' score = 99.5 print('Hello World! ...

  3. RPC基础以及造一个RPC的轮子需要注意些什么

    RPC基础以及造一个RPC的轮子需要注意些什么 前言 rpc即远程过程调用,是分布式系统常用的通信方法.远程可以是在一台机器上的不同进程或在不同一个机器上的不同进程.rpc更看重速度,像调用本地方法一 ...

  4. C# 应用 - 使用 HttpClient 发起 Http 请求

    1. 需要的库类 \Reference Assemblies\Microsoft\Framework\.NETFramework\v4.7.2\System.Net.Http.dll System.N ...

  5. pyspider的环境安装

    第一:确认自己的Python版本3.6.x(因该版本与pyspider较为适应,其他版本易出错) 如果不是3.6版本的,且想将版本替换成3.6版本的有以下处理方法: 1.再装一个3.6版本python ...

  6. 从零开始编写一个BitTorrent下载器

    从零开始编写一个BitTorrent下载器 BT协议 简介 BT协议Bit Torrent(BT)是一种通信协议,又是一种应用程序,广泛用于对等网络通信(P2P).曾经风靡一时,由于它引起了巨大的流量 ...

  7. maven 常用命名

    maven项目,在命令行中操作,非常简洁.高效,现将maven项目常用命令行总结如下: maven命令行命令总结 序号 整理 统计 命令 作用 1 基本 5 mvn -v 查看maven版本 2 mv ...

  8. Java 给PPT添加动画效果(预设动画/自定义动画)

    PPT幻灯片中对形状可设置动画效果,常见的动画效果为内置的固定类型,即动画效果和路径是预先设定好的固定模板,但在设计动画效果时,用户也可以按照自己的喜好自定义动画动作路径.下面,通过Java后端程序代 ...

  9. Androi Studio 之 LinearLayout

    LinearLayout •常用属性 •注意事项 当  android:orientation="vertical"  时, 只有水平方向的设置才起作用,垂直方向的设置不起作用 a ...

  10. Spring笔记(三)

    Spring AOP 一.AOP(概念) 1. 什么是AOP 面向切面编程(方面),利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各个部分之间的耦合度降低,提高程序的可重用性,同时提高了 ...