码迷,mamicode.com
首页 > 其他好文 > 详细

杭电 HDU ACM 1976 Software Version

时间:2015-04-17 13:56:05      阅读:136      评论:0      收藏:0      [点我收藏+]

标签:acm   c++   杭电   算法   编程   



Software Version

Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2728    Accepted Submission(s): 1895


Problem Description
相信大家一定有过在网上下载软件而碰到多个不同版本的情况。

一般来说,软件的版本号由三个部分组成,主版本号(Major Version Number),子版本号(Minor Version Number)和修订号(Revision_Number)。当软件进行了重大的修改时,主版本号加一;当软件在原有基础上增加部分功能时,主版本号不变,子版本号加一;当软件仅仅修正了部分bug时,主版本号和子版本号都不变,修正号加一。
在我们比较软件的两个版本的新旧时,都是先比较主版本号,当主版本号相同时再比较子版本号,前两者都相同的情况下再比较修正号。版本号越大的软件越新。

现在,Lele 在载软件的时候碰到了两个版本,请你告诉他哪个版本更新一些。
 

Input
输入的第一行有一个整数T,代表有T组测试。接下来有T组测试。
每组测试分两行,第一行有三个整数代表第一个软件版本的主版本号,子版本号和修订号。第二行也有三个整数代表第二个软件版本的主版本号,子版本号和修订号。

数据中出现的整数都在[0,1000]范围之内。
 

Output
对于每组测试,如果第一个软件的版本新点,请输出"First",如果第二个软件的版本新点,请输出"Second",否则输出"Same"。
 

Sample Input
3 1 1 0 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1
 

Sample Output
Second First Same
 

Author
linle
 

Source
 

这道题 那么简单 竟然 卡了一会。一开始用scanf输入字符数组 ,然后用比较函数处理,发现空格导致读入间断。然后想到cin忽略空格,可以用string字符串。然而
却仍以空白作为分界,但它却可以依次读入并处理数据,比如1 2 3 先把1插入输入流 2 3 则留在队列中。处理完1后y因为有while循环 又开始读入2 依次进行。
AC:
#include<iostream>
#include<string>
#include<stdio.h>
using namespace std;
int main()
{
 int n,ls[6],j;
 cin>>n;
 while(n--)
 {
     for(int i=0;i<6;i++)
        cin>>ls[i];
     for( j=0;j<3;j++)
     {
         if(ls[j]>ls[j+3])
           {cout<<"First"<<endl;break;}
         else if(ls[j]==ls[j+3])
         {
            continue;
         }
         else
            {cout<<"Second"<<endl;break;}
     }
     if(j==3)
        cout<<"Same"<<endl;

 }
 return 0;
}


杭电 HDU ACM 1976 Software Version

标签:acm   c++   杭电   算法   编程   

原文地址:http://blog.csdn.net/lsgqjh/article/details/45095655

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!