问题

解决(python)

解决 (racket 5.2.1)

  1. ; 定义函数 equal-to-k
  2. ; 它接受一个整数输入 k
  3. ; 它输出一个只返回 true/false 的匿名函数
  4. ; k = 1 时, equal-to-k 的功能可以这样理解
  5. ; (equal-to-k 1) => true
  6. ; (equal-to-k 2) => false
  7. (lambda (n) (if (= k n) true false)))
  8. ; 定义函数 random-list-100-remainder-stats
  9. ; 它不接受任何输入
  10. ; 它输出一个整数型列表 b, 其每个元素的定义如下
  11. ; > 给定一个整数型列表 a,包含 100 个元素,保存 100 个随机的 4 位数。
  12. ; > 整数型列表 b,包含 10 个元素。
  13. ; > 统计a列表中的元素对10求余等于0的个数,保存到b[0]中;
  14. ; > 10求余等于1的个数,保存到b[1]中,……依此类推。
  15. (define (random-list-100-remainder-stats)
  16. [rand-list-100 (for/list ([i 100]) (rand-e4))] ; 生成长度为 100 的列表, 其中每个元素都是 1000~9999 之间的随机数
  17. [get-remainder-by-10 (lambda (n) (modulo n 10))] ; 定义对某整数除以 10 取余数的"生成器"
  18. [remainder-list-100 (map get-remainder-by-10 rand-list-100)] ; 对前面长为 100 的列表批量除以 10 取余数
  19. ; 最后, 对余数做统计, 生成 b 列表
  20. [remainder-list-stats (for/list ([k (in-range 0 10)]) (count (filter-by-k k) remainder-list-100))])
  21. ; 把生成的 b 列表输出出来
  22. remainder-list-stats))
  23. ; 函数调用, 正常执行时, 应输出一个整数的列表
  24. (random-list-100-remainder-stats)