每天一道算法题 时间显示

142 阅读2分钟

每一天一道算法题,从简开始,一起坚持!

题目描述

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

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

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

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

输入描述

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

输出描述

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

输入输出样例

示例 1

输入

46800999

输出

13:00:00

示例 2

输入

1618708103123

输出

01:08:23

评测用例规模与约定

对于所有评测用例,给定的时间为不超过 10^18 的正整数。

解析

思路

根据题目提取到信息,我们需要把毫秒转换为秒根据秒在获得小时-》分钟-》秒,这是具体思路。

陷阱

对于所有评测用例,给定的时间为不超过 10^18 的正整数。

int 类型占4个字节,每个字节占8位,所以一共有32位,除去一位符号位,也就31位,能表示整数大小是2^31 次方 2^10约等于10^3 所以 2^31约等于10^9,题目却给到了10^18,所以我们需要用到long long 类型。

代码如下

#include<iostream>
using namespace std;
​
int main() {
    // 10^18
    long long n;
    cin>>n;
    n /= 1000;  // 去除毫秒
    // 从小时-》秒计算
    int h =  n / 3600;  // 获取小时
    n -= h * 3600;  
    // 获取分钟
    int m = n / 60;
    int s  = n - 60 * m;    
    if (h%24 < 10){
        cout<<0<<h%24<<":";
    }else{
        cout<<h%24<<":";
    }
    if (m < 10){
        cout<<0<<m<<":";
    }else{
        cout<<m<<":";
    }if (s < 10){
        cout<<0<<s;
    }else{
        cout<<s;
    }
​
}

结果

image.png

刚开始学习,存在很多不足之处,希望大家批评和指正,也希望和大家一起进步!