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

相关文章

服务器集群同步时间手记

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,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

批处理以当前时间为文件名创建文件

批处理以当前时间为文件名创建文件 批处理创建空文件 有时候,需要创建以当前时间命名的文件,手动输入当然可以,但是有更省心的方法吗? 假设我是 windows 操作系统,打开命令行。 输入以下命令试试: echo %date:~0,4%_%date:~5,2%_%date:~8,2%_%time:~0,2%_%time:~3,2%_%time:~6,2% 输出类似: 2019_06

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

【MRI基础】TR 和 TE 时间概念

重复时间 (TR) 磁共振成像 (MRI) 中的 TR(重复时间,repetition time)是施加于同一切片的连续脉冲序列之间的时间间隔。具体而言,TR 是施加一个 RF(射频)脉冲与施加下一个 RF 脉冲之间的持续时间。TR 以毫秒 (ms) 为单位,主要控制后续脉冲之前的纵向弛豫程度(T1 弛豫),使其成为显著影响 MRI 中的图像对比度和信号特性的重要参数。 回声时间 (TE)

【算法专场】模拟(下)

目录 前言 38. 外观数列 算法分析 算法思路 算法代码 1419. 数青蛙 算法分析 算法思路 算法代码  2671. 频率跟踪器 算法分析 算法思路 算法代码 前言 在前面我们已经讲解了什么是模拟算法,这篇主要是讲解在leetcode上遇到的一些模拟题目~ 38. 外观数列 算法分析 这道题其实就是要将连续且相同的字符替换成字符重复的次数+