LSNUOJ 1826 软件版本

本文介绍了一种用于比较软件版本新旧的算法,该算法通过依次比较主版本号、子版本号和修订号来确定哪个版本更新。文章提供了一个Java实现示例,详细解释了如何读取用户输入的两个版本号,并输出哪个版本更新或两者相同。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题 D: 软件版本
时间限制: 1 Sec 内存限制: 32 MB
提交: 42 解决: 17
[提交] [状态] [讨论版] [命题人:外部导入]
题目描述

相信大家一定有过在网上下载软件而碰到多个不同版本的情况。一般来说,软件的版本号由三个部分组成,主版本号(Major Version Number),子版本号(Minor Version Number)和修订号(Revision_Number)。当软件进行了重大的修改时,主版本号加一;当软件在原有基础上增加部分功能时,主版本号不变,子版本号加一;当软件仅仅修正了部分bug时,主版本号和子版本号都不变,修正号加一。
在我们比较软件的两个版本的新旧时,都是先比较主版本号,当主版本号相同时再比较子版本号,前两者都相同的情况下再比较修正号。版本号越大的软件越新。
现在,小明在下载软件的时候碰到了两个版本,请你告诉他哪个版本更新一些。

输入

输入的第一行有一个整数T,代表有T组测试。接下来有T组测试。
每组测试分两行,第一行有三个整数代表第一个软件版本的主版本号,子版本号和修订号。第二行也有三个整数代表第二个软件版本的主版本号,子版本号和修订号。
数据中出现的整数都在[0,1000]范围之内。

输出

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

样例输入
3
1 1 0
1 1 1
1 1 1
1 1 0
1 1 1
1 1 1

样例输出
Second
First
Same
注意:此题要注意2 0 0比 1 1 1的版本更新,也就是在3对数中,判断出第一个不相等就可以得出结果,就break!!!,比如:2>1,所以第一个更新,同理,1 2 0和1 1 1,也就是2>1所以第一个更新。

import java.util.Scanner;

public class D {

	public static void main(String[] args) {
		Scanner scanner=new Scanner(System.in);
		int n=scanner.nextInt();
		while(n>0)
		{
			int [] a=new int[3];
			int [] b=new int[3];
			for(int i=0;i<3;i++)
			{
				a[i]=scanner.nextInt();
			}
			for(int i=0;i<3;i++)
			{
				b[i]=scanner.nextInt();
			}
			int ac=0;
			int bc=0;
			for(int i=0;i<3;i++)
			{
				if(a[i]>b[i])
				{
					ac++;
					break;
				}
				else
				{
					if(a[i]<b[i])
					{
						bc++;
						break;
					}
				}
			}
			if(ac>bc)
				System.out.println("First");
			else
			{
				if(ac<bc)
					System.out.println("Second");
				else
				{
					if(ac==bc)
						System.out.println("Same");
				}
			}
			n--;
		}
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值