SDUT 2174回文时间

回文时间

Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^

题目描述

  HH 每天都会熬夜写代码,然后很晚才睡觉,但是每天早晨六点多必须要刷卡出宿舍,这就导致了必须在某些课上睡一会才能保证充沛的体力,当然某些重要的课是不能睡掉的,而某些课是可以睡的,比如《中国传统文化》,但是睡觉是不能被老师发现的,否则......他会以让你重修两年来威胁你。已知老师会在电子表上显示的时间为回文(例如:15:51)的时候来检查有没有人在睡觉,所以必须要在那个时间之前醒来。现在,给出 HH 开始睡觉的时间,你要帮她计算出下一个回文时间。

输入

输入包含多组测试数据,对于每组测试数据:
输入只有一行为一个字符串,字符串格式为"HH:MM",HH 和 MM 都为两位数字(00 ≤ HH ≤ 23, 00 ≤ MM ≤ 59)。

输出

对于每组测试数据,输出只有一行为下一个回文时间。

示例输入

12:21
23:59

示例输出

13:31
00:00

提示

 

来源

qinchuan

示例程序

//题目要求的是字符串输入输出,虽然我的这个方法也能做对(结果对),但在OJ上不能AC!
/*#include<stdio.h>
int main()
{
    int i,x,y;
    int c,d;
    int a[16]= {00,01,02,03,04,05,10,11,12,13,14,15,20,21,22,23};
    int b[16]= {00,10,20,30,40,50,01,11,21,31,41,51,02,12,22,32};
    while(~scanf("%d:%d",&x,&y))
    {
        if(x==a[15])
            printf("%02d:%02d\n",a[0],b[0]);
        else
        {
            for(i=0; i<15; i++)
            {
                if(x>=a[i]&&x<a[i+1] && y<b[i])
                {
                    c=a[i];
                    d=b[i];
                    break;
                }
                else if(x>=a[i]&&x<a[i+1] && y>=b[i])
                {
                    c=a[i+1];
                    d=b[i+1];
                    break;
                }
            }
            printf("%02d:%02d\n",c,d);
        }
    }
    return 0;
}*/
//以下上看的学长得解题报告写的
#include<stdio.h>
int main()
{
    int hour,minute,a,b;
    char s[10];
    while(scanf("%s",s)!=EOF)
    {
        hour=(s[0]-'0')*10+(s[1]-'0');
        minute=(s[3]-'0')*10+(s[4]-'0');
        a=hour/10;
        b=hour%10;
        if(a+b*10>minute && a+b*10<59)
            printf("%02d:%02d\n",hour,a+b*10);
        else
        {
            if(hour==23)
                printf("%02d:%02d\n%",0,0);
            else
            {
                while(!(hour+1<23 &&(hour+1)%10*10+(hour+1)/10<60))
                {
                    hour+=1;
                }
                printf("%02d:%02d\n",hour+1,(hour+1)%10*10+(hour+1)/10);
            }
        }
    }
    return 0;
}

总的来说就是个简单的字符串的应用,仔细点想细心点就能想出来的题。(注意输出时位数不够用0补齐的写法,这个题我的最大收获就在这儿)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值