鸡兔同笼第一种方法

题目描述

一个笼子里面关了鸡和兔子(鸡有2只脚,兔子有4只脚,没有例外)。
已经知道了笼子里面脚的总数a,问笼子里面至少有多少只动物,至多有多少只动物。

输入

先输入一个整数n,表示总共的组数。然后输入数据,每组测试数据占1行,每行一个正整数a (a < 32768)。

输出

输出包含n行,每行对应一个输入,包含两个正整数,第一个是最少的动物数,第二个是最多的动物数,两个正整数用一个空格分开。
如果没有满足要求的答案,则输出两个0。

样例输入

2
3
20

样例输出

0 0
5 10
import java.util.Scanner;

public class Main {
	
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
	    int a,min,max;
	    while(sc.hasNext()) {
	    	a = sc.nextInt();
	    	min = 16384;
	    	max = -16384;
	    	for(int x=0;x<=a/2;x++) {
	    		//最小的鸡数量到最大的鸡数量
	    		for(int y=0;y<=a/4;y++) {
	    			//最小的兔数量到最大的兔数量
	    			if(x*2+y*4==a) {
	    				max = max>(x+y)?max:(x+y);
	    				min = min<(x+y)?min:(x+y);
	    			}
	    		}
	    	}
	    	if(max==-16384||min==16384||a==2)
	    		System.out.printf("0"+" "+"0"+"\n");
	    	else
	    		System.out.printf("%d %d\n",min,max);
	    }
	}
}

这种方法中含有两个for循环,直接令电脑自己计算,比较无逻辑,需要的时间比较多,可能引起时间超限。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值