7-8 毕业聚会 (10分)

毕业在即,三位小伙伴马上要分别。为了在未来的某个日子可以见面,三位小伙伴有了一个约定,假设在未来的某一年,三位小伙伴的年龄的末尾正好出现3、6、9三个数,那么他们会再次相聚。

现在问题来了,假设今年三位小伙伴的年龄分别是x,y,z,那么,他们三人最早几年后可以相聚呢?

输入格式:

输入数据包括三个整数x,y,z,分别表示三位伙伴的年龄。

输出格式:

如果小伙伴最早在n年后可以相见(不包括当前这一年),那么请输出这个n;如果100年内都不存在这样的情况,输出**:so sad!**

输入样例:

在这里给出一组输入。例如:

25 22 28

输出样例:

在这里给出相应的输出。例如:

1

这里感觉写得太长了

import java.util.*;
public class Main {
	public static void main(String[] args) {
		
		Scanner input = new Scanner(System.in);
		int agea = input.nextInt();
		int ageb = input.nextInt();
		int agec = input.nextInt();
		int i = 0;		
		for(i = 0; i < 100; i++) {
			if((agea + i) % 10 == 3) {
				if((ageb + i) % 10 == 6 && (agec + i) % 10 == 9 ||
				   (ageb + i) % 10 == 9 && (agec + i) % 10 == 6) {
					break;
				}
			}
			else if((agea + i) % 10 == 6) {
				if((ageb + i) % 10 == 3 && (agec + i) % 10 == 9 ||
					(ageb + i) % 10 == 9 && (agec + i) % 10 == 3) {
					break;
				}
			}
			else if((agea + i) % 10 == 9) {
				if((ageb + i) % 10 == 3 && (agec + i) % 10 == 6 ||
					(ageb + i) % 10 == 6 && (agec + i) % 10 == 3) {
					break;
				}
			}	
		}
		if(i == 100) {
			System.out.println("so sad!");
		}
		else {
			System.out.println(i);
		}
	}
}

同学的代码,代码终于短了

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		
		Scanner input = new Scanner(System.in);
		
		int pa = input.nextInt();
		int pb = input.nextInt();
		int pc = input.nextInt();
		int year = -1;
		for(int i = 1;i <= 100; i++) {
			pa++;
			pb++;
			pc++;
			//这里就是3 6 9都可以进,且不是10,20 ....这些整数
			if((pa % 10)%3 == 0 && pa % 10 != 0) {
				//与上一个数不同
				if((pb % 10)%3 == 0 && (pb % 10) != (pa % 10) && pb % 10 != 0) {
					//与上两个数都不同
					if((pc % 10) % 3 == 0 && (pc % 10) != (pb % 10) && (pc % 10) != (pa % 10) && pc % 10 != 0) {
						year = i;
						break;
					}
				}
			}
		}
		if(year == -1) {
			System.out.println("so sad!");
		}
		else {
			System.out.println(year);
		}
	}
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值