百度之星之D:共同狂欢

简介: 在北京和纳斯达克的同学们每一个小时整点时就会通一次电话,对一下表,确认一切相关活动都精确同步。但是要注意,在两边的同学位于不同的时区,在夏时制时,两地时差12小时,因此,每次对表都需要做一下时区转换。

时间限制:

1000ms

内存限制:

131072kB

描述

百度2005年8月5日上市时,在北京和纳斯达克的同学们每一个小时整点时就会通一次电话,对一下表,确认一切相关活动都精确同步。但是要注意,在两边的同学位于不同的时区,在夏时制时,两地时差12小时,因此,每次对表都需要做一下时区转换。你来帮我们完成这个有点麻烦的工作吧。

输入

输入的第一行包括一个整数T(T ≤ 30),表示测试数据的组数;接下去的T行每行包括一个时间,表示两地中的一个地方同学报出的整点的时间,表示成“H:M”的形式,其中H是小时(0 ≤H < 24,且当H小于10的时候可以表示成1位或者2位的形式)、M是分钟(0 ≤ M < 60,且当M小于10的时候可以表示成1位或者2位)。

输出

每个测试数据输出一行,当是整点对时时,输出时区转换后的小时结果;当不是整点对时时,输出0。

样例输入

4

12:00

01:01

3:00

00:00

样例输出

24

0

15

12

【答案】

#include <iostream>
#include <string>
#include <stdlib.h>
using namespace std;
int main(void)
{
    int iGroups;
    const char* pStrSubLeft = new char[10];
    const char* pStrSubRight = new char[10];
    string strSubLeft;    
    string strSubRight;   
    int iInterVal = 0;    
    int iLen = 0;         
    int iMinute = 0;
    int iHour = 0;
    int iResult = 0;
    
    cin >> iGroups;
    if(iGroups > 30)
    {
        cout << "Error!" << endl;
        return -1;
    }
    
    string strTimeArr[30];
    for( int i = 0; i < iGroups; i++)
    {
        cin >> strTimeArr[i];
        iInterVal = strTimeArr[i].find(':');
        
        iLen = strTimeArr[i].length();
        strSubRight = strTimeArr[i].substr(iInterVal+1,iLen);
        pStrSubRight = strSubRight.c_str();
        iMinute = atoi(pStrSubRight);
        
        strSubLeft = strTimeArr[i].substr(0,iInterVal);
        pStrSubLeft = strSubLeft.c_str();
        iHour = atoi(pStrSubLeft);
 
        if(iHour < 0 || iHour >= 24)
        {
            cout << "Error!" << endl;
            return -1;
        }
        if(iMinute < 0 || iMinute >= 60)
        {
            cout << "Error!" << endl;
            return -1;
        }
        
        if(iMinute != 0)
        {
            iResult = 0;
        }
        else
        {
            if(iHour >= 0 && iHour <= 12)
            {
                iResult = iHour + 12;
            }
            else if(iHour > 12 && iHour <= 24)
            {
                iResult = iHour - 12;
            }
        }
        cout << iResult << endl;
    }
    cout << endl;
 
    return 0;
}

作者:铭毅天下
原文:https://blog.csdn.net/laoyang360/article/details/7621101
版权声明:本文为博主原创文章,转载请附上博文链接!

相关文章
|
传感器 人工智能 自然语言处理
AI黑科技贯穿全程,2020百度好奇夜掀起科技狂欢
AI黑科技贯穿全程,2020百度好奇夜掀起科技狂欢
148 0
AI黑科技贯穿全程,2020百度好奇夜掀起科技狂欢
|
安全 程序员 开发者
SegmentFault 助力百度轻应用 Hackathon —— 程序员的七夕狂欢
本周末,在SegmentFault 的特别支持下百度在北京、上海、深圳三地同时举办了一场十分盛大的黑客马拉松——百度轻应用 Hackathon,这是一次面向广大移动互联网开发者、传统品牌商户及企业的轻应用创意开发活动。主题“Connecting 连接人与生活”,意为致力于搭建服务提供方与移动开发者的桥梁,让那些由移动创业者、开发者、设计师、产品经理组成的团队,通过思想碰撞创新最优质的轻应用解决方案。
213 0
SegmentFault 助力百度轻应用 Hackathon —— 程序员的七夕狂欢
百度之星之D:共同狂欢
百度2005年8月5日上市时,在北京和纳斯达克的同学们每一个小时整点时就会通一次电话,对一下表,确认一切相关活动都精确同步。但是要注意,在两边的同学位于不同的时区,在夏时制时,两地时差12小时,因此,每次对表都需要做一下时区转换。你来帮我们完成这个有点麻烦的工作吧。
145 0
百度之星之D:共同狂欢
|
1月前
|
存储 Kubernetes 容器
百度搜索:蓝易云【Kubernetes使用helm部署NFS Provisioner】
现在,你已经成功使用Helm部署了NFS Provisioner,并且可以在Kubernetes中创建使用NFS存储的PersistentVolumeClaim。
158 10
|
1月前
百度搜索:蓝易云【什么是HTTP长轮询?】
现在,HTTP长轮询逐渐被WebSocket等更高效的实时通信技术所替代,但了解HTTP长轮询仍然有助于理解实时数据推送的基本原理。
95 9
|
1月前
|
移动开发 Shell Linux
百度搜索:蓝易云【Shell错误:/bin/bash^M: bad interpreter: No such file or directory】
将 `your_script.sh`替换为你的脚本文件名。运行此命令后,脚本文件的换行符将被转换为Linux格式,然后就可以在Linux系统上正常执行脚本了。
45 8
|
1月前
百度搜索:蓝易云【ipmitool配置BMC的ip】
以上操作将配置BMC的IP地址为新的值。请注意,操作BMC需要谨慎,确保你对服务器有足够的权限,并且仔细检查新的IP地址、子网掩码和默认网关,以免导致服务器网络失联。
45 7
|
1月前
|
Kubernetes 应用服务中间件 nginx
百度搜索:蓝易云【使用Kubernetes部署Nginx应用教程】
现在,你已经成功在Kubernetes集群上部署了Nginx应用。通过访问Service的外部IP地址,你可以访问Nginx服务。
54 4
|
1月前
|
缓存 网络协议 Linux
百度搜索:蓝易云【解决github push/pull报错443】
通过以上方法,你有望解决GitHub push/pull报错443的问题。如果问题仍然存在,建议检查GitHub的状态页面,看是否有正在维护或故障的情况。
90 3
|
1月前
|
Linux Perl
百度搜索:蓝易云【Linux常用命令awk】
以上仅是awk命令的一些常见用法,它还有许多更复杂的功能和用法,可以根据需要灵活运用。awk在文本处理和数据分析中非常实用,是Linux系统中的一把利器。
34 2