I'm trying to figure out how to incorporate 3 variables into my tail recursion code for racket

前端 未结 2 1224
囚心锁ツ
囚心锁ツ 2021-01-23 19:37

Write a tail recursive function called popadd that models a population with P people at time t = 0 and adds d people per year.

(define (popadd t  P)
  (if (= t 0         


        
2条回答
  •  不思量自难忘°
    2021-01-23 20:27

    Note that neither your code nor the code in the other answer is tail-recursive: in a recursive call like (+ (f ...)), f is not in tail position. To make the code tail-recursive you need the result of the recursive call be the result of the overall call (so in the above example, + is in tail position). To do this you need an auxiliary function. Here is a way of doing it which relies only on local define:

    (define (popadd t P d)
      (define (popadd-loop tau pop)
        (if (zero? tau)
            pop
            (popadd-loop (- tau 1) (+ pop d))))
      (popadd-loop t P)) 
    

    Here is essentially the same thing using named-let, which is nicer:

    (define (popadd t P d)
      (let popadd-loop ([tau t] [pop P])
        (if (zero? tau)
            pop
            (popadd-loop (- tau 1) (+ pop d)))))
    

    Finally note that this problem has a closed-form solution:

    (define (popadd t P d)
      (+ P (* t d)))
    

    I really wish that people trying to teach programming knew enough maths to not set problems which have trivial closed-form answers, as doing so encourages people to write inefficient (in the complexity-class sense) code. Obviously this is not your fault: it's your teacher's.

提交回复
热议问题