【Python】PAT-1026 程序运行时间(AC)
題目
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解答
分析:
題目中主要分為兩步,
需要特別注意python 中的round來進行四舍五入,值是不準確的(和浮點數的精度有關)
例如下圖,理想中的輸出結果是59,但確是58。
代碼:
# 轉化成 h,m,s def convertSec(x):h = x // 3600x = x % 3600m = x // 60x = x % 60s = xreturn [h,m,s]# 用于四舍五入兩位整數 def update(x):point = x.find(".")if point == -1:return int(x)else:if int(x[point+1]) >= 5:return int(x[:point])+1else:return int(x[:point])x,y = list(map(int,input().split(" "))) time = convertSec((y - x) / 100)time[2] = update(str(time[2]))# %02d,不夠兩位,左邊補0 print("%02d:%02d:%02d" % tuple(time))AC截圖
總結
以上是生活随笔為你收集整理的【Python】PAT-1026 程序运行时间(AC)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Python】PAT-1024-科学计
- 下一篇: 【村通网】凭啥说python3.6+字典