zl程序教程

您现在的位置是:首页 >  其他

当前栏目

【基础入门题013】求连续根号的值

基础入门 连续 013
2023-09-14 09:01:29 时间

【基础入门题】2021.11.09

(编程语言不限)F(n)=√[1+√[2+√[3+…+√[n-1+√[n]]]]], 编程求F(50), F(100), F(3000)的值(方括号表示数字在对应根号下)

编程语言:包括但不限于Python
题目来源:派森特给站每日刷题频道 


方法一:从最里层的根号开始算,初始值为√n,循环变量从n-1递减到1。

def F(n):
	res = n**0.5
	for i in range(n-1,0,-1):
		res = (i + res)**0.5
	return res

>>> F(50)
1.7579327566180045
>>> F(100)
1.7579327566180045
>>> F(3000)
1.7579327566180045
>>> 

方法二: 循环变量从n开始递减,此时初始值为0,相当最里层的看作:n+√0。

def F(n):
	res = 0
	for i in range(n,0,-1):
		res = (i + res)**0.5
	return res

变量也可以递增,计算式中做个减法:

def F(n):
	res = 0
	for i in range(n):
		res = (n-i + res)**0.5
	return res

 while循环也可以,只是循环变量的自增或自减都要自己写代码:

def F(n):
	res = 0
	while n>0:
		res = (n + res)**0.5
		n -= 1
	return res


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