总时间限制: 1000ms 内存限制: 65536kB
描述
一个笼子里面关了鸡和兔子(鸡有2只脚,兔子有4只脚,没有例外)。已经知道了笼子里面脚的总数a,问笼子里面至少有多少只动物,至多有多少只动物
输入
第1行是测试数据的组数n,后面跟着n行输入。每组测试数据占1行,每行一个正整数a (a < 32768)
输出
输出包含n行,每行对应一个输入,包含两个正整数,第一个是最少的动物数,第二个是最多的动物数,两个正整数用一个空格分开
如果没有满足要求的答案,则输出两个0。
样例输入
2
3
20
样例输出
0 0
5 10
思路
设脚的个数为 X.
- 如果 X 是奇数,则无解,输出
0 0
. - 如果 X 是偶数,且能被4整除,则最少有
X/4
只兔子,最多有X/2
只鸡. - 如果 X 是偶数,但不能被4整除,则最少有
X/4
只兔子外加1只鸡,最多有X/2
只鸡.
代码
#include<iostream>
using namespace std;
int main() {
int number, feet = 0;
cin >> number;
for(int i = 0; i < number; i++) {
cin >> feet;
if(feet % 2 != 0) { // If feet is an odd number
printf("0 0\n");
continue;
}
// If feet is an even number
if(feet % 4 == 0) {
printf("%d %d\n", feet / 4, feet / 2);
}else {
printf("%d %d\n", feet/4 + 1, feet / 2);
}
}
return 0;
}