博客
关于我
1026 程序运行时间 (15 分)
阅读量:580 次
发布时间:2019-03-09

本文共 1391 字,大约阅读时间需要 4 分钟。

要测量C语言程序的运行时间,我们通常使用 clock() 函数来捕捉程序的时钟打点。时钟打点是程序执行时间的基本单位,其速度由 CLK_TCK 决定。假设 CLK_TCK 为 100,即每秒100个打点。

步骤说明:

  • 读取输入: 获取两次调用 clock() 函数时的时钟打点数 C1 和 C2。
  • 计算时间差: 计算两次打点的差值,即 (C2 - C1),这表示函数运行所消耗的指针周期。
  • 转换为秒数: 将指针周期除以 CLK_TCK(即 100),得到以秒为单位的运行时间。需注意小数部分,如果不足一秒,需四舍五入到最接近的秒数。
  • 格式化输出: 将秒数转换为 hh:mm:ss 格式,确保每部分为两位数字,不足补零。
  • 输入转换与计算示例:

    输入:123 4577973

    差值:4577973 - 123 = 4577850
    秒数:4577850 / 100 = 45.77850
    四舍五入:46秒
    转换为时间:
    46秒 ÷ 3600 = 0小时剩余46秒
    46秒 ÷ 60 = 0分钟剩余46秒
    46秒 = 0小时 0分钟 0秒
    最终时间:00:00:46 不符合实际样本,请检查步骤是否正确。

    发现问题:应将 4577850 秒转换为小时、分钟和秒。

    正确转换方法:

    总秒数 4577850秒:
    4577850 ÷ 3600 = 1275小时余 30 秒
    1275小时 → 523分钟余30秒
    523分钟 → 8小时 43分钟 30秒
    最终时间:8:43:30。可能仍需要校准正确定转换方式。

    在代码中,提取整小时、整分钟和余下的秒数:setPassword("时间转换逻辑似乎有误,请重新审视步骤并优化计算方式");

    为了测量C语言程序的运行时间,我们使用clock()函数,其中包含时钟打点。CK_TCK告诉我们每秒钟有多少打点。假设CK_TCK为100,步骤如下:

  • 读取C1和C2:输入两次时钟打点。
  • 计算时间差:C2 - C1。
  • 转秒:/ 100。
  • 倒转换:转成小时、分钟和秒,四舍五入不足1秒并格式化为两位数字。
  • 示例输入:123 4577973

    计算
    4577973 - 123 = 4577850
    4577850 / 100 = 45.77850秒 → 46秒
    分解为0小时:0:46
    格式化为:00:00:46

    但根据实际情况,应将秒数转换为实际时间,如8:43:30。

    最终代码实现:

    #include 
    #include
    #include
    int main(){ int B, E, YourSec, Hour, Minute, Second; scanf("%d %d", &B, &E); long long diff = E - B; long long runtime = diff / 100; YourSec = runtime; Minute = YourSec / 60; int sec = YourSec % 60; Minute = Minute % 60; Hour = YourSec / 3600; printf("%02d:%02d:%02d", Hour, Minute, sec); return 0;}

    转载地址:http://seipz.baihongyu.com/

    你可能感兴趣的文章
    openlayers 入门教程(四):layers 篇
    查看>>
    OpenLayers 项目分析(三)-OpenLayers中定制JavaScript内置类
    查看>>
    Openlayers下载与加载geoserver的wms服务显示地图
    查看>>
    VS.NET版本与VC版本对应关系
    查看>>
    Openlayers中使用Cluster+Overlay实现点击单个要素和聚合要素时显示不同弹窗
    查看>>
    Openlayers中使用Cluster实现点位元素重合时动态聚合与取消聚合
    查看>>
    Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合
    查看>>
    Openlayers中使用Image的rotation实现车辆定位导航带转角(判断车辆图片旋转角度)
    查看>>
    Openlayers中使用Overlay实现点击要素弹窗并且弹窗随之移动
    查看>>
    Vmware系列&虚拟机系列【仅供参考】:使用vCenter Auto Deploy制作ESXI系统封装(适合高版本vSphere)
    查看>>
    Openlayers中加载GeoJson文件显示地图
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片图层组
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片地图并显示
    查看>>
    Openlayers中多图层遮挡时调整图层上下顺序
    查看>>
    Openlayers中实现地图上打点并显示图标和文字
    查看>>
    Openlayers中实现地图上添加一条红色直线
    查看>>
    Openlayers中将某个feature置于最上层
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers入门教程 --- 万字长篇
    查看>>