算法题每日一练---第10天:时间显示

简介: 小蓝要和朋友合作开发一个时间显示的网站。在服务器上,朋友已经获取了当前的时间,用一个整数表示,值为从 1970 年 11 月 11 日 00:00:00 到当前时刻经过的毫秒数。

一、问题描述


小蓝要和朋友合作开发一个时间显示的网站。

在服务器上,朋友已经获取了当前的时间,用一个整数表示,值为从 1970 年 11 月 11 日 00:00:00 到当前时刻经过的毫秒数。

现在,小蓝要在客户端显示出这个时间。小蓝不用显示出年月日,只需要显示出时分秒即可,毫秒也不用显示,直接舍去即可。

给定一个用整数表示的时间,请将这个时间对应的时分秒输出。


二、题目要求


考察

时间转换,数学思想
建议用时10~15min


输入描述

输入的一行包含一个整数,表示时间。


输出描述

输出时分秒表示的当前时间,格式形如 HH:MM:SS,其中 HH 表示时,值为 0 到 23,MM 表示分,值为 0 到 59,SS 表示秒,值为 0 到 59。时、分、秒 不足两位时补0。


三、问题分析


这一题不像求解日期问题,需要考虑到闰年的2月份是28天还是29天,只需要先将毫秒数换算成秒数,其中换算进制1s=1000ms(不要搞错了,一开始我以为1s等于60ms,结果算了半天)。

最后直接求解秒数除以3600再取模,分钟数除以60再取模,秒数直接取模,输出结果的时候要注意补位,可以先看一下拓展部分的相关知识点。

拓展

  • 时、分、秒 不足两位时补0,可以使用%02d,不足两位前面补0
  • %d是int普通的存储,%2d按宽度为2,采用右对齐方式输出,若数据位数不到2位,则左边补空格
  • 毫秒存储超出int范围,采取long long int 存储


四、编码实现


#include <iostream>usingnamespacestd;
longlongintsum; 
intmain()
{
cin>>sum;//输入时间毫秒数 inti,s=0,f=0,m=0,n;//初始化 n=sum/1000;//换算成秒 s=(n/3600)%24;//计算出时 f=(n/60)%60;//计算出分 m=n%60;//计算出秒 printf("%02d:%02d:%02d",s,f,m);//输出结果 return0;
}


五、输出结果


测试用例1 46800999

22.png

测试用例2 1618708103123


23.png

相关文章
|
1月前
|
算法 Java 程序员
【算法每日一练及解题思路】有n级台阶,一次只能上1级或2级,共有多少种走法?
本文深入解析了“爬楼梯问题”,探讨了递归与迭代两种解法,并提供了Java代码实现。通过分析问题本质,帮助读者理解动态规划技巧,提高解决实际编程问题的能力。关键词:Java, 算法, 动态规划, 爬楼梯问题, 递归, 迭代。
66 0
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
192 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
150 1
算法题每日一练---第76天:丑数 l
|
算法
算法题每日一练---第75天:Nim 游戏
你和你的朋友,两个人一起玩 Nim 游戏。
327 0
算法题每日一练---第75天:Nim 游戏
|
算法
算法题每日一练---第74天:快乐数
编写一个算法来判断一个数 n 是不是快乐数。
180 0
算法题每日一练---第74天:快乐数
|
存储 算法
算法题每日一练---第73天:加一
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
162 0
算法题每日一练---第73天:加一
|
算法
算法题每日一练---第72天:数字 1 的个数
给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。
228 0
算法题每日一练---第72天:数字 1 的个数
|
存储 算法
算法题每日一练---第71天:回文数
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
158 0
算法题每日一练---第71天:回文数