sum of a list in scheme












2















I'm beginner in functional programming and scheme language.



I found a way to build the sum of a list:



(define (sum lst)
(if (empty? lst)
0
(+ (car lst) (sum (cdr lst)))))

(sum (list 1 2 3))


My question is: is there a way to build the sum of a list without a extra function like sum, just using the "+" function like this:



(+ 1 2 3)









share|improve this question





























    2















    I'm beginner in functional programming and scheme language.



    I found a way to build the sum of a list:



    (define (sum lst)
    (if (empty? lst)
    0
    (+ (car lst) (sum (cdr lst)))))

    (sum (list 1 2 3))


    My question is: is there a way to build the sum of a list without a extra function like sum, just using the "+" function like this:



    (+ 1 2 3)









    share|improve this question



























      2












      2








      2








      I'm beginner in functional programming and scheme language.



      I found a way to build the sum of a list:



      (define (sum lst)
      (if (empty? lst)
      0
      (+ (car lst) (sum (cdr lst)))))

      (sum (list 1 2 3))


      My question is: is there a way to build the sum of a list without a extra function like sum, just using the "+" function like this:



      (+ 1 2 3)









      share|improve this question
















      I'm beginner in functional programming and scheme language.



      I found a way to build the sum of a list:



      (define (sum lst)
      (if (empty? lst)
      0
      (+ (car lst) (sum (cdr lst)))))

      (sum (list 1 2 3))


      My question is: is there a way to build the sum of a list without a extra function like sum, just using the "+" function like this:



      (+ 1 2 3)






      scheme racket






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Feb 3 '18 at 19:07









      Mat

      166k29318348




      166k29318348










      asked Feb 3 '18 at 19:05









      SergeSerge

      162




      162
























          3 Answers
          3






          active

          oldest

          votes


















          5














          You can apply list of arguments to a function. So in this case you can:



          > (apply + (list 1 2 3))
          6





          share|improve this answer































            2














            The reference for MIT/Gnu-Scheme says, that + takes ANY number of arguments.
            I am sure, that this standard.



            In general:



            (define (foo . args) ....)


            is used like (foo) or (foo x) or (foo x y), (foo x y z), .... . Inside foo the args will be '(), (x), (x y) or (x y z).



            See exercise 2.20 in SICP or MIT/Scheme Reference 9.2 chap 2.1



            This means:



            For the arithmetic procedures +, *, - and / your procedure is not necessary, because they are defined for any number of arguments, including zero and one.
            This is also true for some other built-in procedures.
            For your own procedures you can use the dotted-tail notation.



            You can download the MIT/Scheme Reference from the GNU-Pages. I think it helps for all implementation of Scheme, because extension of the standard are
            described. Most parts are easy to read.






            share|improve this answer

































              1














              Common Lisp programmers should look to
              [http://www.gigamonkeys.com/book/functions.html].



              Here you must use &rest instead of >.<
              (defun + (&rest numbers) ...)



              Both lisp-dialects know default, optional and rest parameters.






              share|improve this answer























                Your Answer






                StackExchange.ifUsing("editor", function () {
                StackExchange.using("externalEditor", function () {
                StackExchange.using("snippets", function () {
                StackExchange.snippets.init();
                });
                });
                }, "code-snippets");

                StackExchange.ready(function() {
                var channelOptions = {
                tags: "".split(" "),
                id: "1"
                };
                initTagRenderer("".split(" "), "".split(" "), channelOptions);

                StackExchange.using("externalEditor", function() {
                // Have to fire editor after snippets, if snippets enabled
                if (StackExchange.settings.snippets.snippetsEnabled) {
                StackExchange.using("snippets", function() {
                createEditor();
                });
                }
                else {
                createEditor();
                }
                });

                function createEditor() {
                StackExchange.prepareEditor({
                heartbeatType: 'answer',
                autoActivateHeartbeat: false,
                convertImagesToLinks: true,
                noModals: true,
                showLowRepImageUploadWarning: true,
                reputationToPostImages: 10,
                bindNavPrevention: true,
                postfix: "",
                imageUploader: {
                brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
                contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
                allowUrls: true
                },
                onDemand: true,
                discardSelector: ".discard-answer"
                ,immediatelyShowMarkdownHelp:true
                });


                }
                });














                draft saved

                draft discarded


















                StackExchange.ready(
                function () {
                StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f48600963%2fsum-of-a-list-in-scheme%23new-answer', 'question_page');
                }
                );

                Post as a guest















                Required, but never shown

























                3 Answers
                3






                active

                oldest

                votes








                3 Answers
                3






                active

                oldest

                votes









                active

                oldest

                votes






                active

                oldest

                votes









                5














                You can apply list of arguments to a function. So in this case you can:



                > (apply + (list 1 2 3))
                6





                share|improve this answer




























                  5














                  You can apply list of arguments to a function. So in this case you can:



                  > (apply + (list 1 2 3))
                  6





                  share|improve this answer


























                    5












                    5








                    5







                    You can apply list of arguments to a function. So in this case you can:



                    > (apply + (list 1 2 3))
                    6





                    share|improve this answer













                    You can apply list of arguments to a function. So in this case you can:



                    > (apply + (list 1 2 3))
                    6






                    share|improve this answer












                    share|improve this answer



                    share|improve this answer










                    answered Feb 3 '18 at 19:22









                    rsmrsm

                    1,26631623




                    1,26631623

























                        2














                        The reference for MIT/Gnu-Scheme says, that + takes ANY number of arguments.
                        I am sure, that this standard.



                        In general:



                        (define (foo . args) ....)


                        is used like (foo) or (foo x) or (foo x y), (foo x y z), .... . Inside foo the args will be '(), (x), (x y) or (x y z).



                        See exercise 2.20 in SICP or MIT/Scheme Reference 9.2 chap 2.1



                        This means:



                        For the arithmetic procedures +, *, - and / your procedure is not necessary, because they are defined for any number of arguments, including zero and one.
                        This is also true for some other built-in procedures.
                        For your own procedures you can use the dotted-tail notation.



                        You can download the MIT/Scheme Reference from the GNU-Pages. I think it helps for all implementation of Scheme, because extension of the standard are
                        described. Most parts are easy to read.






                        share|improve this answer






























                          2














                          The reference for MIT/Gnu-Scheme says, that + takes ANY number of arguments.
                          I am sure, that this standard.



                          In general:



                          (define (foo . args) ....)


                          is used like (foo) or (foo x) or (foo x y), (foo x y z), .... . Inside foo the args will be '(), (x), (x y) or (x y z).



                          See exercise 2.20 in SICP or MIT/Scheme Reference 9.2 chap 2.1



                          This means:



                          For the arithmetic procedures +, *, - and / your procedure is not necessary, because they are defined for any number of arguments, including zero and one.
                          This is also true for some other built-in procedures.
                          For your own procedures you can use the dotted-tail notation.



                          You can download the MIT/Scheme Reference from the GNU-Pages. I think it helps for all implementation of Scheme, because extension of the standard are
                          described. Most parts are easy to read.






                          share|improve this answer




























                            2












                            2








                            2







                            The reference for MIT/Gnu-Scheme says, that + takes ANY number of arguments.
                            I am sure, that this standard.



                            In general:



                            (define (foo . args) ....)


                            is used like (foo) or (foo x) or (foo x y), (foo x y z), .... . Inside foo the args will be '(), (x), (x y) or (x y z).



                            See exercise 2.20 in SICP or MIT/Scheme Reference 9.2 chap 2.1



                            This means:



                            For the arithmetic procedures +, *, - and / your procedure is not necessary, because they are defined for any number of arguments, including zero and one.
                            This is also true for some other built-in procedures.
                            For your own procedures you can use the dotted-tail notation.



                            You can download the MIT/Scheme Reference from the GNU-Pages. I think it helps for all implementation of Scheme, because extension of the standard are
                            described. Most parts are easy to read.






                            share|improve this answer















                            The reference for MIT/Gnu-Scheme says, that + takes ANY number of arguments.
                            I am sure, that this standard.



                            In general:



                            (define (foo . args) ....)


                            is used like (foo) or (foo x) or (foo x y), (foo x y z), .... . Inside foo the args will be '(), (x), (x y) or (x y z).



                            See exercise 2.20 in SICP or MIT/Scheme Reference 9.2 chap 2.1



                            This means:



                            For the arithmetic procedures +, *, - and / your procedure is not necessary, because they are defined for any number of arguments, including zero and one.
                            This is also true for some other built-in procedures.
                            For your own procedures you can use the dotted-tail notation.



                            You can download the MIT/Scheme Reference from the GNU-Pages. I think it helps for all implementation of Scheme, because extension of the standard are
                            described. Most parts are easy to read.







                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited Jan 2 at 3:57









                            rsm

                            1,26631623




                            1,26631623










                            answered Feb 3 '18 at 22:47









                            Georg FussGeorg Fuss

                            1778




                            1778























                                1














                                Common Lisp programmers should look to
                                [http://www.gigamonkeys.com/book/functions.html].



                                Here you must use &rest instead of >.<
                                (defun + (&rest numbers) ...)



                                Both lisp-dialects know default, optional and rest parameters.






                                share|improve this answer




























                                  1














                                  Common Lisp programmers should look to
                                  [http://www.gigamonkeys.com/book/functions.html].



                                  Here you must use &rest instead of >.<
                                  (defun + (&rest numbers) ...)



                                  Both lisp-dialects know default, optional and rest parameters.






                                  share|improve this answer


























                                    1












                                    1








                                    1







                                    Common Lisp programmers should look to
                                    [http://www.gigamonkeys.com/book/functions.html].



                                    Here you must use &rest instead of >.<
                                    (defun + (&rest numbers) ...)



                                    Both lisp-dialects know default, optional and rest parameters.






                                    share|improve this answer













                                    Common Lisp programmers should look to
                                    [http://www.gigamonkeys.com/book/functions.html].



                                    Here you must use &rest instead of >.<
                                    (defun + (&rest numbers) ...)



                                    Both lisp-dialects know default, optional and rest parameters.







                                    share|improve this answer












                                    share|improve this answer



                                    share|improve this answer










                                    answered Feb 4 '18 at 22:42









                                    Georg FussGeorg Fuss

                                    1778




                                    1778






























                                        draft saved

                                        draft discarded




















































                                        Thanks for contributing an answer to Stack Overflow!


                                        • Please be sure to answer the question. Provide details and share your research!

                                        But avoid



                                        • Asking for help, clarification, or responding to other answers.

                                        • Making statements based on opinion; back them up with references or personal experience.


                                        To learn more, see our tips on writing great answers.




                                        draft saved


                                        draft discarded














                                        StackExchange.ready(
                                        function () {
                                        StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f48600963%2fsum-of-a-list-in-scheme%23new-answer', 'question_page');
                                        }
                                        );

                                        Post as a guest















                                        Required, but never shown





















































                                        Required, but never shown














                                        Required, but never shown












                                        Required, but never shown







                                        Required, but never shown

































                                        Required, but never shown














                                        Required, but never shown












                                        Required, but never shown







                                        Required, but never shown







                                        Popular posts from this blog

                                        MongoDB - Not Authorized To Execute Command

                                        in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith

                                        How to fix TextFormField cause rebuild widget in Flutter