【基础入门题022】《孙子算经》之鸡兔同笼

【基础入门题】2021.11.19

《孙子算经》今有雉兔同笼,上有三十五头,下有九十四足,问雉兔各几何?

编程语言:包括但不限于Python
题目来源:派森特给站每日刷题频道
————————————————
即解整数不定方程组: i+j==35; i*2+j*4==94; i,j>=1

双循环

def ChickenAndRabbit():
	for i in range(36):
		for j in range(36):
			if i*2+j*4==94 and i+j==35:
				return i,j

			
>>> ChickenAndRabbit()
(23, 12)

 单循环

def ChickenAndRabbit():
	for i in range(36):
		if i*2+(35-i)*4==94:
			return i,35-i

		
>>> ChickenAndRabbit()
(23, 12)

抬腿法”一:

不管什么动物,都抬起两条腿:即变成“上有三十五头,下有二十四足(94-35x2=24)”,余下24足当然全是兔子的,所有兔子有12只,鸡有35-12=23只。

def ChickenAndRabbit(heads, feet):
	rabbits = (feet - heads*2)//2
	chickens = heads - rabbits
	return chickens,rabbits

>>> ChickenAndRabbit(35,94)
(23, 12)

抬腿法”二:

不管什么动物,都抬起一半的腿:即变成“上有三十五头,下有四十七足(94/2)”,余下47足减去总头数35就是兔子的数量,所有兔子有47-35=12只,鸡有35-12=23只。

def ChickenAndRabbit(heads, feet):
	rabbits = feet//2 - heads
	chickens = heads - rabbits
	return chickens,rabbits

>>> ChickenAndRabbit(35,94)
(23, 12)

扩展题

《孙子算经》中还有另外一题:今有兽,六首四足;禽,四首二足,上有七十六首,下有四十六足。问:禽、兽各几何?答曰:八兽、七禽。

def Animals():
	for i in range(77):
		for j in range(77):
			if i*6+j*4==76 and i*4+j*2==46:
				return i,j

			
>>> Animals()
(8, 7)

现代扩展的题目,变量可以是小数的,也可能是负数的

1. 蜘蛛有8条腿,蜻蜓有6条腿和2对翅膀,蝉有6条腿和1对翅膀。这三种小虫共18只,有118条腿和20对翅膀。每种小虫各几只?
2. 红铅笔每支0.19元,蓝铅笔每支0.11元,两种铅笔共买了16支,花了2.80元。问红,蓝铅笔各买几支?
3. 一份稿件,甲单独打字需6小时完成.乙单独打字需10小时完成,甲单独打若干小时后,因有事由乙接着打完,共用了7小时。甲打字用了多少小时?
4. 1998年时,父母年龄(整数)和是78岁,兄弟的年龄和是17岁。四年后(2002年)父的年龄是弟的年龄的4倍,母的年龄是兄的年龄的3倍。那么当父的年龄是兄的年龄的3倍时,是公元哪一年?
5. 某次数学考试考五道题,全班52人参加,共做对181道题,已知每人至少做对1道题,做对1道的有7人,5道全对的有6人,做对2道和3道的人数一样多,那么做对4道的人数有多少人?
6. 某次数学竞赛共有10题,答对加4分,答错或不答扣2分。一位同学得了4分,请问这位同学答对几题?

 

欢迎加入csdn社区! https://bbs.csdn.net/forums/PythonTogetherhttps://bbs.csdn.net/forums/PythonTogether

Guess you like

Origin blog.csdn.net/boysoft2002/article/details/121429073