Search code examples
schemelispracketmultiplicationcdr

multiplying list of items by a certain number 'x'


How would you write a procedure that multiplies each element of the list with a given number (x).If I give a list '(1 2 3) and x=3, the procedure should return (3 6 9)

My try:

(define (mul-list list x)
(if (null? list)
1
(list(* x (car list))(mul-list (cdr list)))))

The above code doesnt seem to work.What changes do I have to make ? Please help

Thanks in advance.


Solution

  • This is the text book example where you should use map, instead of reinventing the wheel:

    (define (mul-list lst x)
      (map (lambda (n) (* x n)) lst))
    

    But I guess that you want to implement it from scratch. Your code has the following problems:

    • You should not call list a parameter, that clashes with the built-in procedure of the same name - one that you're currently trying to use!
    • The base case should return an empty list, given that we're building a list as output
    • We build lists by consing elements, not by calling list
    • You forgot to pass the second parameter to the recursive call of mul-list

    This should fix all the bugs:

    (define (mul-list lst x)
      (if (null? lst)
          '()
          (cons (* x (car lst))
                (mul-list (cdr lst) x))))
    

    Either way, it works as expected:

    (mul-list '(1 2 3) 3)
    => '(3 6 9)