HDU4177 Avoiding a disaster(模拟时间)

2024-01-14 02:48

本文主要是介绍HDU4177 Avoiding a disaster(模拟时间),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:   http://www.cnblogs.com/13224ACMer/p/4728968.html

题意: 题意真的没啥难度,就是每次给定三个时间,根据差值判断中间时间,如果三个时间中只有一个可以作为中间时间的话,那就输出这个时间。若没有中间时间或者有多个时间可以作为中间时间的话就输出“你还是看太阳吧”。

错因分析:这道题没啥知识或技术上的难点,就是道纯数学题而已。我和队友当时一是没有看到最大时间差值不能超过480分钟即八小时,二是一共就十二个小时我们非要根据实际情况分为上午12小时,下午12小时,然后将每个时间化成上午对应的分钟数和下午对应的分钟数,这样就有六个时间了,然后分别判断每个时间是否是中间时间。当时还因12:00要不要分成0:00和24:00纠结了好久,也尝试了好多遍,结果WA5次,最终也没做出来,我们想的真的是太简单了。我最近几场组队赛每次都读不了几道题,大多时间是队友告诉我题意然后我敲代码,有的时候理解上难免有出入,作为集训队里唯一的女队,我相信我们能坚持下来并且越做越好的!

题目分析: 其实画一条时间轴就可以很明白了,感谢伟大的学长告诉了我们最简单的思路。

——————————|——————|——————|———|

——————————0:00 ———-5:00————10:00—12:00

对于样例1一      5:00,10:00,12:00,很明显化成分钟后不能直接根据差值的绝对值判断中间值。这里应该按0:00,5:00,10:00判断,故中间值是5:00。因而应该将每个点都进行移动看能否找到中间值,其实和我们最初想的差不多,只不过我们当时把问题复杂化了大哭

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstdlib>
#include<map>
#include<string>
#include<vector>
#include<cstring>
using namespace std;
const int maxn = 666;
int judge(int a, int b, int c)//判断a是否为中间时间
{int ans1 = abs(a - b);ans1 = min(ans1, 720 - ans1);//差值不能超过8小时,一共就12个小时即720分钟,对两部分取小就好,小的那部分绝对不会超过的。int ans2 = abs(a - c);ans2 = min(ans2, 720 - ans2);return ans1 == ans2;//差值相等说明a是中间值,返回1,否则返回0
}
int main()
{char ch;int t, h, m;scanf("%d",&t);while(t--){int minute[3],f[3];//将每次输入的三个时间转化成分钟保存在minute[]数组中//f[]数组用于保存可能是中间值的时间for(int i = 0; i < 3; i++){scanf("%d%c%d",&h,&ch,&m);//直接读入数据,不用管前导零minute[i] = h * 60 + m;}f[0] = judge(minute[0], minute[1], minute[2]);//判断minute[0]是否是中间时间f[1] = judge(minute[1], minute[0], minute[2]);//判断minute[1]是否是中间时间f[2] = judge(minute[2], minute[0], minute[1]);//判断minute[2]是否是中间时间int ans = f[0] + f[1] + f[2];//只能有一种情况,即f[0] f[1] f[2] 的值只能有一个为1,其他两个都为0if(ans == 1){if(f[0]) printf("The correct time is %d:%02d\n", minute[0] / 60, minute[0] % 60);//输出唯一的中间时间if(f[1]) printf("The correct time is %d:%02d\n", minute[1] / 60, minute[1] % 60);if(f[2]) printf("The correct time is %d:%02d\n", minute[2] / 60, minute[2] % 60);}else printf("Look at the sun\n");//我当时被这道一直wa的题弄得郁闷的想看太阳啊}return 0;
}


这篇关于HDU4177 Avoiding a disaster(模拟时间)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/603683

相关文章

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

Java将时间戳转换为Date对象的方法小结

《Java将时间戳转换为Date对象的方法小结》在Java编程中,处理日期和时间是一个常见需求,特别是在处理网络通信或者数据库操作时,本文主要为大家整理了Java中将时间戳转换为Date对象的方法... 目录1. 理解时间戳2. Date 类的构造函数3. 转换示例4. 处理可能的异常5. 考虑时区问题6.

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

usaco 1.2 Transformations(模拟)

我的做法就是一个一个情况枚举出来 注意计算公式: ( 变换后的矩阵记为C) 顺时针旋转90°:C[i] [j]=A[n-j-1] [i] (旋转180°和270° 可以多转几个九十度来推) 对称:C[i] [n-j-1]=A[i] [j] 代码有点长 。。。 /*ID: who jayLANG: C++TASK: transform*/#include<

hdu4431麻将模拟

给13张牌。问增加哪些牌可以胡牌。 胡牌有以下几种情况: 1、一个对子 + 4组 3个相同的牌或者顺子。 2、7个不同的对子。 3、13幺 贪心的思想: 对于某张牌>=3个,先减去3个相同,再组合顺子。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOExcepti

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点