PAT Basic 1026
1026 程序运行时间 (15 分)
要获得一个 C 语言程序的运行时间,常用的方法是调用头文件 time.h,其中提供了 clock() 函数,可以捕捉从程序开始运行到 clock() 被调用时所耗费的时间。这个时间单位是 clock tick,即“时钟打点”。同时还有一个常数 CLK_TCK,给出了机器时钟每秒所走的时钟打点数。于是为了获得一个函数 f 的运行时间,我们只要在调用 f 之前先调用 clock(),获得一个时钟打点数 C1;在 f 执行完成后再调用 clock(),获得另一个时钟打点数 C2;两次获得的时钟打点数之差 (C2-C1) 就是 f 运行所消耗的时钟打点数,再除以常数 CLK_TCK,就得到了以秒为单位的运行时间。
这里不妨简单假设常数 CLK_TCK 为 100。现给定被测函数前后两次获得的时钟打点数,请你给出被测函数运行的时间。
输入格式:
输入在一行中顺序给出 2 个整数 C1 和 C2。注意两次获得的时钟打点数肯定不相同,即 C1 < C2,并且取值在 [0,107]。
输出格式:
在一行中输出被测函数运行的时间。运行时间必须按照 hh:mm:ss
(即2位的 时:分:秒
)格式输出;不足 1 秒的时间四舍五入到秒。
输入样例:
123 4577973
输出样例:
12:42:59
对于四舍五入,除以100后,单位就是秒,需要四舍五入到秒
也就是小数点后一位,大于等于0.5就是进位,小于0.5就是舍,故而最后加上了0.5,再用int接收他
这一点忘了是在哪看到的了,居然还有印象
另外一点需要注意的是
int s = ((c2 - c1)/CLK_TCK)+0.5;
这一句,如果c1,c2都是int类型,最后的结果都不会正确
按理说不应该吖,但事实就是出错了,小数被舍去了,不加后面的0.5,他就是个整数
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <vector>
#include<algorithm>
#include<string>
#include<math.h>
#define max 1000
#define debug 0
using namespace std;
int main() {
#if debug
freopen("in.txt", "r", stdin);
#endif
const int CLK_TCK = 100;
double c1, c2;
cin >> c1 >> c2;
int s = ((c2 - c1)/CLK_TCK)+0.5;
int min = s / 60;
int hour = min / 60;
s = s % 60;
min = min % 60;
if (hour < 10)
cout << 0 << hour<<":";
else
cout << hour << ":";
if(min<10)
cout << 0 << min << ":";
else
cout << min << ":";
if(s<10)
cout << 0 << s <<endl;
else
cout << s <<endl;
#if debug
freopen("CON", "r", stdin);
#endif
return 0;
}
int s = ((c2 - c1)/CLK_TCK)+0.5;
这一句,如果c1,c2都是int类型,最后的结果都不会正确
按理说不应该吖,但事实就是出错了,小数被舍去了,不加后面的0.5,他就是个整数
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
· 本地部署 DeepSeek:小白也能轻松搞定!
· 如何给本地部署的DeepSeek投喂数据,让他更懂你
· 从 Windows Forms 到微服务的经验教训
· 李飞飞的50美金比肩DeepSeek把CEO忽悠瘸了,倒霉的却是程序员
· 超详细,DeepSeek 接入PyCharm实现AI编程!(支持本地部署DeepSeek及官方Dee
2018-03-09 伽卡拉他学生客户端无法运行任务管理器的解决方法