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

相关文章

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

Python使用pynput模拟实现键盘自动输入工具

《Python使用pynput模拟实现键盘自动输入工具》在日常办公和软件开发中,我们经常需要处理大量重复的文本输入工作,所以本文就来和大家介绍一款使用Python的PyQt5库结合pynput键盘控制... 目录概述:当自动化遇上可视化功能全景图核心功能矩阵技术栈深度效果展示使用教程四步操作指南核心代码解析

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法

macOS Sequoia 15.5 发布: 改进邮件和屏幕使用时间功能

《macOSSequoia15.5发布:改进邮件和屏幕使用时间功能》经过常规Beta测试后,新的macOSSequoia15.5现已公开发布,但重要的新功能将被保留到WWDC和... MACOS Sequoia 15.5 正式发布!本次更新为 Mac 用户带来了一系列功能强化、错误修复和安全性提升,进一步增

Pandas进行周期与时间戳转换的方法

《Pandas进行周期与时间戳转换的方法》本教程将深入讲解如何在pandas中使用to_period()和to_timestamp()方法,完成时间戳与周期之间的转换,并结合实际应用场景展示这些方法的... 目录to_period() 时间戳转周期基本操作应用示例to_timestamp() 周期转时间戳基

JavaScript时间戳与时间的转化常用方法

《JavaScript时间戳与时间的转化常用方法》在JavaScript中,时间戳(Timestamp)通常指Unix时间戳,即从1970年1月1日00:00:00UTC到某个时间点经过的毫秒数,下面... 目录1. 获取当前时间戳2. 时间戳 → 时间对象3. 时间戳php → 格式化字符串4. 时间字符

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及