c语言时间戳转换日期格式_c语言时间转换为时间戳

c语言时间戳转换日期格式_c语言时间转换为时间戳时间戳是计算机中记录时间的一种方法,某一时刻的时间戳指的是从1970年1月1日0时0分0秒开始到该时刻总共过了多少秒。请编程任意输入一个整数,然后计算出它表示的是哪一天哪一刻。问题分析输入:任意整数n(0≤n≤2147483647),表示从1970年1月1日0时0分0秒到该时刻过了多少秒。输出:y年m月d日H时M分S秒,y、m…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

时间戳是计算机中记录时间的一种方法,某一时刻的时间戳指的是从 1970 年 1 月 1 日 0 时 0 分 0 秒开始到该时刻总共过了多少秒。请编程任意输入一个整数,然后计算出它表示的是哪一天哪一刻。

问题分析

输入:任意整数 n(0≤n≤2147483647),表示从 1970 年 1 月 1 日 0 时 0 分 0 秒到该时刻过了多少秒。

输出:y 年 m 月 d 日 H 时 M 分 S 秒,y、m、d、H、M、S 为六个整数。

假设一年 12 个月,每个月有 30 天,那么:

一天的时间(秒)为:days = 24×60×60 = 86400 秒;

一个月的时间(秒)为:months = days×30 = 2592000 秒;

一年的时间(秒)为:years = months×12 = 31104000 秒;

2147483647=231-1,它是 32 位操作系统能够处理的最大的整型数。根据 n 的取值范围,定义变量 n 的数据类型应该为 long int 型。

n 除以一年的时间(秒)years 的商加上 1970 就是具体年份 y,余数再除以一月的时间(秒)months 的商加 1 就是月份 m,再次得到的余数除以一天的时间(秒)days 的商加 1 就是日期 d,第三次得到的余数除以 3600 的商就是小时数 H,第四次得到的余数除以 60 的商就是分 M 和余数就是秒 S。

y = n / years + 1970

m = n % years / months + 1

d = n % years % months / days + 1

H = n % years % months % days / 3600

M = n % years % months % days % 3600 / 60

S = n % years % months % days % 3600 % 60

图 1 展示了普通时间值和时间戳(秒单位的值)相互转换的过程。

d5c18e40983ce6dbad33ea1f947468cb.gif

图 1:普通时间值和时间戳(秒单位的值)相互转换

算法描述

70e6839250dc1c9fbe5885505739fc01.gif

代码清单 1:C语言程序源代码(时间戳)

#include

#include

int main( )

{

system(“color 70”);

long days = 24 * 60 * 60;

long months = days * 30;

long years = months * 12;

long n,y,m,d,HH,MM,SS;

printf(“输入整数 n(0-2147483647):”);

scanf(“%ld”,&n);

y = n / years + 1970;

m = n % years / months + 1;

d = n % years % months / days + 1;

HH = n % years % months % days / 3600;

MM = n % years % months % days % 3600 / 60;

SS = n % years % months % days % 3600 % 60;

printf(“\n%d年%d月%d日%d时%d分%d秒\n”,y,m,d,HH,MM,SS);

system(“pause”);

return 0;

}

运行结果为:

输入整数 n(0-2147483647):4464502

1970年2月22日16时8分22秒

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/188115.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • C++最长上升子序列

    C++最长上升子序列现有数列a1,a2,a3……aN。在其中找到严格递增序列ai1,ai2,ai3,……aiK(1<=i1

    2022年6月12日
    35
  • bfs是什么意思_bfs轮

    bfs是什么意思_bfs轮Rubik 先生在发明了风靡全球的魔方之后,又发明了它的二维版本——魔板。这是一张有 8 个大小相同的格子的魔板:1 2 3 48 7 6 5我们知道魔板的每一个方格都有一种颜色。这 8 种颜色用前 8 个正整数来表示。可以用颜色的序列来表示一种魔板状态,规定从魔板的左上角开始,沿顺时针方向依次取出整数,构成一个颜色序列。对于上图的魔板状态,我们用序列 (1,2,3,4,5,6,7,8) 来表示,这是基本状态。这里提供三种基本操作,分别用大写字母 A,B,C 来表示(可以通过这些操作改变魔板

    2022年8月9日
    4
  • SSDP协议_固态硬盘两种协议

    SSDP协议_固态硬盘两种协议SSDP,即简单服务发现协议(SSDP,SimpleServiceDiscoveryProtocol),是一种应用层协议,是构成通用即插即用(UPnP)技术的核心协议之一。 实现简单服务发现协议是在HTTPU和HTTPMU的基础上实现的协议。按照协议的规定,当一个控制点(客户端)接入网络的时候,它可以向一个特定的多播地址的SSDP端口使用M-SEARCH方法发送“ssdp:…

    2022年10月11日
    2
  • platform_driver_register 与 platform_device_register「建议收藏」

    platform_driver_register 与 platform_device_register「建议收藏」
    platfrom_driver_register()是在设备注册时进行绑定的.以USB为例:先插上USB设备并挂到总线上,然后在安装USB设备驱动的过程中,从总线上遍历各个设备,看是否有与驱动相匹配的设备,如果有,则两者绑定,就是platfrom_driver_register()
     
    platfrom_device_register()是在驱动注册时进行绑定的.以USB为例:先安装USB驱动程序,然后当USB设备插入时,就遍历总线上各个驱动,看两者是否匹配,如果相配则

    2022年7月14日
    20
  • web网页设计代码模板_web网页设计源代码

    web网页设计代码模板_web网页设计源代码代码分享:https://pan.baidu.com/s/1xf4AQlfM8e6Nvw2oXUdbrA提取码:ap1v

    2022年9月23日
    3
  • 面试 SQL整理 常见的SQL面试题:经典50题

    面试 SQL整理 常见的SQL面试题:经典50题目录​SQL基础知识整理:常见的SQL面试题:经典50题三、50道面试题2.汇总统计分组分析3.复杂查询sql面试题:topN问题4.多表查询【面试题类型总结】这类题目属于行列如何互换,解题思路如下:其他面试题:SQL基础知识整理:select查询结果如:[学号,平均成绩:组函数avg(成绩)]from从哪张表中查找数…

    2022年5月20日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号