我的PAT系列文章更新重心已移至Github,歡迎來(lái)看PAT題解的小伙伴請(qǐng)到Github Pages瀏覽最新內(nèi)容。此處文章目前已更新至與Github Pages同步。歡迎star我的repo。
題目
要獲得一個(gè) C 語(yǔ)言程序的運(yùn)行時(shí)間,常用的方法是調(diào)用頭文件 time.h,其中提供了 clock() 函數(shù),可以捕捉從程序開(kāi)始運(yùn)行到 clock()
被調(diào)用時(shí)所耗費(fèi)的時(shí)間。這個(gè)時(shí)間單位是 clock tick,即“時(shí)鐘打點(diǎn)”。同時(shí)還有一個(gè)常數(shù)
CLK_TCK,給出了機(jī)器時(shí)鐘每秒所走的時(shí)鐘打點(diǎn)數(shù)。于是為了獲得一個(gè)函數(shù) 的運(yùn)行時(shí)間,我們只要在調(diào)用
之前先調(diào)用
clock(),獲得一個(gè)時(shí)鐘打點(diǎn)數(shù) C1;在 執(zhí)行完成后再調(diào)用 clock(),獲得另一個(gè)時(shí)鐘打點(diǎn)數(shù) C2;兩次獲得的時(shí)鐘打點(diǎn)數(shù)之差 (C2-C1)
就是 運(yùn)行所消耗的時(shí)鐘打點(diǎn)數(shù),再除以常數(shù) CLK_TCK,就得到了以秒為單位的運(yùn)行時(shí)間。
這里不妨簡(jiǎn)單假設(shè)常數(shù) CLK_TCK 為 100?,F(xiàn)給定被測(cè)函數(shù)前后兩次獲得的時(shí)鐘打點(diǎn)數(shù),請(qǐng)你給出被測(cè)函數(shù)運(yùn)行的時(shí)間。
輸入格式:
輸入在一行中順序給出 2 個(gè)整數(shù) C1 和 C2。注意兩次獲得的時(shí)鐘打點(diǎn)數(shù)肯定不相同,即 C1 C2,并且取值在
。
輸出格式:
在一行中輸出被測(cè)函數(shù)運(yùn)行的時(shí)間。運(yùn)行時(shí)間必須按照 hh:mm:ss(即2位的 時(shí):分:秒)格式輸出;不足 1 秒的時(shí)間四舍五入到秒。
輸入樣例:
123 4577973
輸出樣例:
12:42:59
思路
這道題也是最簡(jiǎn)單的一類(lèi)題,考慮到四舍五入就行了。
代碼
最新代碼@github,歡迎交流
#include <stdio.h>
int main()
{
int C1, C2, T;
scanf("%d %d", &C1, &C2);
T = (C2 - C1 + 50) / 100; /* rounding */
printf("%02d:%02d:%02d", T/3600, T%3600/60, T%60);
return 0;
}