当前位置: > > > > 根据需要的次数执行函数
根据需要的次数执行函数
来源: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
以上就是《根据需要的次数执行函数》的详细内容,更多关于的资料请关注米云公众号!
