鸡兔同笼问题加强版

描述

已知鸡和兔的总数量为 n,总腿数为 m。输入 n 和 m,依次输出鸡和兔的数目,如果无解,则输出 "No answer"(不要引号)。

输入描述

第一行输入一个数据 a,代表接下来共有几组数据,在接下来的 (a≤100000)

a 行里,每行都有一个 n 和 m。(0<m,n≤1000000)

输出描述

输出鸡兔的个数,或者 No answer

样例输入 1

复制代码
2
14 32
10 16

样例输出 1

复制代码
12 2
No answer

提示

数据范围与提示

a≤100000,0<m,n≤1000000

题解:

对于这个问题,我们可以先用数学方法进行计算,鸡的数量记j,兔子数量记i,

i + j = n

4i + 2j = m

那么鸡的数量为 (4n-m)/2 兔子的数量为 (m-2n)/2

不成立的条件有四种:

1. 鸡的数量小于零

2.兔子的数量小于零

3.总腿数比总只数少(肯定不成立,这里不考虑去胳膊少腿的情况)

4.总腿数为奇数( 4i + 2j = m,一定是偶数

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int main(){
	int n,m,num;
	cin >> num;
	for(int i=0;i<num;i++){
		cin >> n >> m;
		if(m < n || (m-2*n)/2 < 0 || (4*n-m)/2 < 0 || m%2!=0 ){
			cout << "No answer" << endl;
		}else{
			cout << (4*n-m)/2 << " " << (m-2*n)/2 << endl;
		}
	}
}
相关推荐
2301_8079973815 分钟前
代码随想录-day26
数据结构·c++·算法·leetcode
闭着眼睛学算法24 分钟前
【双机位A卷】华为OD笔试之【排序】双机位A-银行插队【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
TL滕25 分钟前
从0开始学算法——第一天(认识算法)
数据结构·笔记·学习·算法
小欣加油26 分钟前
leetcode 3318 计算子数组的x-sum I
c++·算法·leetcode·职场和发展
love is sour44 分钟前
聚类(Clustering)详解:让机器自己发现数据结构
算法·支持向量机·聚类
烟袅1 小时前
LeetCode 142:环形链表 II —— 快慢指针定位环的起点(JavaScript)
前端·javascript·算法
CoovallyAIHub1 小时前
OCR战场再起风云:LightOnOCR-1B凭什么比DeepSeekOCR快1.7倍?(附演示开源地址)
深度学习·算法·计算机视觉
海琴烟Sunshine2 小时前
leetcode 190. 颠倒二进制位 python
python·算法·leetcode
Xの哲學2 小时前
Linux eMMC子系统深度解析:从硬件协议到内核实现
linux·网络·算法·架构·边缘计算
AI柠檬2 小时前
C语言基于MPI并行计算矩阵的乘法
c语言·c++·算法