问题
思路说明
本问题是一个普通的对整数数组的操作,在下面的Python解决方法中,主要是尝试了python的一个内置函数reduce。
解决(Python)
解法 (racket 5.2.1)
; 定义一个函数 operate-int-list
; 它接受一个正整数输入 n
; 它的输出是一个列表
; 列表的第一项是一个长度为 n 的列表, 此列表的每个元素都是一个 1~100 之间的伪随机数
; 所有伪随机数中的最大者
; 所有伪随机数中的最小者
; 所有伪随机数中平均值,以有理数形式表示
(define (operate-int-list n)
(if (<= n 0)
false
(let*
([rand1to100 (lambda () (+ 1 (random 100)))]
[max-int (apply max random-list)]
[sum (apply + random-list)]
[average (/ (apply + random-list) (length random-list))])
(list random-list
max-int min-int sum average))))
; 函数调用,当程序运行正常时,运算结果在形式上类似于以下结果,
; 但每次的结果列表都有一定的随机性