当前位置: > > > > 根据需要的次数执行函数
来源:stackoverflow
2024-04-25 15:51:40
0浏览
收藏
欢迎各位小伙伴来到,相聚于此都是缘哈哈哈!今天我给大家带来《根据需要的次数执行函数》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!
问题内容
计算给定整数的平方和,不包括任何负数。 输入的第一行将是一个整数 n (1 <= n <= 100),指示要遵循的测试用例的数量。 每个测试用例将由一行整数 x (0 < x <= 100) 组成,后跟另一行由 x 个空格分隔的整数 yn (-100 <= yn <= 100) 组成。 对于每个测试用例,计算整数的平方和(排除任何负数),并在输出中打印计算出的总和。
注意:在收到所有输入之前不应有输出。 注2:不要在测试用例解决方案之间放置空行。 注3:从标准输入获取输入,并输出到标准输出。
规则 使用 go 编程语言编写您的解决方案 您的源代码必须是单个文件(包 main) 不要使用任何 for 语句 您只能使用标准库包
“我面临的问题” 根据输入测试用例,下面的“square”函数没有执行所需的次数。为了满足特定要求,我不允许使用“for”语句。请帮帮我。语言是go。
package main import "fmt" var s []int func square(l int) { i := 0 sum := 0 Square: if l > 0 { s[i] = s[i] * s[i] sum = sum + s[i] i++ l-- goto Square } fmt.Println(sum) } func myfunc(a int) { Here: if a > 0 { var b int fmt.Scanln(&b) if b > 0 { s = append(s, b) } a-- goto Here } } func main() { var a int fmt.Scanln(&a) TestCases: if a > 0 { var T int fmt.Scanln(&T) myfunc(T) a-- goto TestCases } square(len(s)) }
解决方案
这是使用递归的实现:
package main import "fmt" func testcase(n int) { if n <= 0 { return } var x int fmt.scanf("%d", &x) fmt.println(sumofsquare(x)) testcase(n-1) } func sumofsquare(x int) int { if x == 0 { return 0 } var y int fmt.scanf("%d", &y) if y > 0 { return y*y + sumofsquare(x-1) } return sumofsquare(x-1) } func main() { var n int fmt.scanf("%d", &n) testcase(n) }
这是一个示例输出:
$ go run main.go 2 4 3 -1 1 14 5 9 6 -53 32 16 206 1397
以上就是《根据需要的次数执行函数》的详细内容,更多关于的资料请关注公众号!