乙级|1026.程序运行时间

题目描述

要获得一个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

我的代码

#include
int main(){
    double t;
    int c1,c2,h,m,s;
    scanf("%d %d",&c1,&c2);
    t=((double)c2-(double)c1)/100;   //要精确到小数位
    if(t-(c2-c1)/100>=0.5){   //如果小数位的数大于0.5
        t=((c2-c1)/100)+1;   //则直接进1
        for(h=0;h<60;h++){   //开始暴力求解
            for(m=0;m<60;m++){
                for(s=0;s<60;s++){
                    if(h*3600+m*60+s==t){
                        if(h<10&&m>=10&&s>=10){   //要按照格式输出
                            printf("0%d:%d:%d",h,m,s);
                        }
                        if(h>=10&&m<10&&s>=10){
                            printf("%d:0%d:%d",h,m,s);
                        }
                        if(h>=10&&m>=10&&s<10){
                            printf("%d:%d:0%d",h,m,s);
                        }
                        if(h>=10&&m>=10&&s>=10){
                            printf("%d:%d:%d",h,m,s);
                        }
                        if(h<10&&m<10&&s>=10){
                            printf("0%d:0%d:%d",h,m,s);
                        }
                        if(h<10&&m>=10&&s<10){
                            printf("0%d:%d:0%d",h,m,s);
                        }
                        if(h>=10&&m<10&&s<10){
                            printf("%d:0%d:0%d",h,m,s);
                        }
                        if(h<10&&m<10&&s<10){
                            printf("0%d:0%d:0%d",h,m,s);
                        }
                         
                    }
                }
            }
        }
    }
    else{   //如果小数位小于0.5
        t=(c2-c1)/100;   //不进位,只取整数
        for(h=0;h<60;h++){
            for(m=0;m<60;m++){
                for(s=0;s<60;s++){
                    if(h*3600+m*60+s==t){
                        if(h<10&&m>=10&&s>=10){
                            printf("0%d:%d:%d",h,m,s);
                        }
                        if(h>=10&&m<10&&s>=10){
                            printf("%d:0%d:%d",h,m,s);
                        }
                        if(h>=10&&m>=10&&s<10){
                            printf("%d:%d:0%d",h,m,s);
                        }
                        if(h>=10&&m>=10&&s>=10){
                            printf("%d:%d:%d",h,m,s);
                        }
                        if(h<10&&m<10&&s>=10){
                            printf("0%d:0%d:%d",h,m,s);
                        }
                        if(h<10&&m>=10&&s<10){
                            printf("0%d:%d:0%d",h,m,s);
                        }
                        if(h>=10&&m<10&&s<10){
                            printf("%d:0%d:0%d",h,m,s);
                        }
                        if(h<10&&m<10&&s<10){
                            printf("0%d:0%d:0%d",h,m,s);
                        }
                        
                    }
                }
            }
        }
    }
    return 0;
} 

我的分析

这道题的题目一开始吓了一跳,以为是很高深的定义,结果仔细的读完题目之后才发现其实很简单,就是要注意四舍五入与按照格式输出。这道题因为给定的数字不大,所以我第一个想到的方法就是暴力法求解,一个一个试,利用三重循环来求出这三个数,代码这么长的原因主要是要把题目规定的格式给细分清楚再输出,虽然很长,但还是比较容易理解的。

优化算法

#include
int main(){
    int c1,c2,ans;
    scanf("%d %d",&c1,&c2);
    ans=c2-c1;
    if(ans%100>=50){  //四舍五入的操作
        ans=(ans/100)+1;  //大于则进位
    }
    else{
        ans=ans/100;  //小于的退位
    }
    printf("%02d:%02d:%02d",ans/3600,ans%3600/60,ans%3600%60);  //按照格式输出
    return 0;
} 

你可能感兴趣的:(乙级|1026.程序运行时间)