提示:2021年试题F
一、题目描述
小蓝要和朋友合作开发一个时间显示的网站。
在服务器上,朋友已经获取了当前的时间,用一个整数表示,值为从 19701970 年 11 月 11 日 00:00:0000:00:00 到当前时刻经过的毫秒数。
现在,小蓝要在客户端显示出这个时间。小蓝不用显示出年月日,只需要显示出时分秒即可,毫秒也不用显示,直接舍去即可。
给定一个用整数表示的时间,请将这个时间对应的时分秒输出。
输入描述:
输入一行包含一个整数,表示时间。
输出描述:
输出时分秒表示的当前时间,格式形如 HH:MM:SS,其中 HH 表示时,值为 00 到 2323,MM 表示分,值为
00 到 5959,SS 表示秒,值为 00 到 5959。时、分、秒 不足两位时补前导 00。
输入输出样例:
示例 1:
输入:46800999
输出:13:00:00
示例 2:
输入:1618708103123
输出:01:08:23
评测用例规模与约定
对于所有评测用例,给定的时间为不超过 1018的正整数。
二、解题过程
1.变量规模
1.1整型
- 对整形int来说,一个整形占用32位,即4Byte,取值范围为-231~+(231-1),可以记住绝对值在109范围以内的整数都可以定义为int型。
- 对长整型long long来说,一个整数占用64位,即8Byte,取值范围为-263~+(263-1),如果题目要求的整数取值范围超过2147483647(如1010),就要用long long存储。
看到要求109以内或者32位整数,就用int来存储;如果是1018以内或者64位整数,要用long long存储。
1.2浮点型
- 对单精度float来说,一个浮点型占用32bit,其中1bit作为符号位,8bit作为指数位,23bit作为尾数位,可以存放的浮点数范围是-2128 ~ +2128,但是其有效精度只有6~7位。
- 对双精度double来说,一个浮点型占用64bit,其中1bit作为符号位,11bit作为指数位,52bit作为尾数位,可以存放的浮点数范围是-21024 ~ +21024,其有效精度有15~16位。
2.参考程序
代码如下(示例):
#include <stdio.h>
#define ll unsigned long long
int main(){
ll num;
scanf("%lld",&num);
num=num%(24*60*60*1000);
num=num/1000;
int ss=num%60;
num=num/60;
int mm=num%60;
num=num/60;
int hh=num;
printf("%02d:%02d:%02d",hh,mm,ss);
return 0;
}