PAT Basic 1026. 程序運(yùn)行時(shí)間(15)(C語(yǔ)言實(shí)現(xiàn))

我的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ù) f 的運(yùn)行時(shí)間,我們只要在調(diào)用 f 之前先調(diào)用
clock(),獲得一個(gè)時(shí)鐘打點(diǎn)數(shù) C1;在 f 執(zhí)行完成后再調(diào)用 clock(),獲得另一個(gè)時(shí)鐘打點(diǎn)數(shù) C2;兩次獲得的時(shí)鐘打點(diǎn)數(shù)之差 (C2-C1)
就是 f 運(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,并且取值在 [0, 10^7]

輸出格式:

在一行中輸出被測(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;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容