Solved

concept check please

Posted on 2004-09-26
5
191 Views
Last Modified: 2011-09-20
1. A stack can be used to permute numbers. For example, assume you have '1
2 3' as an input stream (reading from the right) into your stack. Assume
you can push or pop in any order at any time (with the restriction that
you cannot pop from an empty stack). Thus, if you push all three and
pop_top all three, your output is '1 2 3'. What are all the possible
permutations for output you can achieve for this input stream?

ANSWER: 5

321   312   231   213   123

The choices in this case are limited by the fact that you cannot execute
a pop on an empty stack and you cannot push from an empty input stream.
Thus allowable choices can be shown by using a binary decision tree.

<EXAMPLE>

                        PUSH
                       /      \
                    POP       PUSH
                   /          /   \
                PUSH        POP    PUSH
               /  \        /   \      \
           POP    PUSH   POP  PUSH    POP
           /        \     /      \       \
       PUSH        POP  PUSH     POP     POP
        |           |    |        |       |
       POP         POP   POP     POP     POP
      321          312   231     213     123

2. Prove by induction that for any n >= 1, 1^3 + 2^3 + 3^3 + ... + n^3 =
(1 + 2 + 3 + ... + n)^2.

Call this summation SUM3.

*1. Establish a base case:     SUM3(1) = 1^3 = 1.

*2. Now assume SUM3 true for some k.  Recall that we proved by induction
    (in class) that 1 + 2 + 3 + ... + k =  2 | k(k+1) (meaning 2 divides
    k(k+1) )   thus:

    SUM3(k) =  ( 2 | k(k+1) ) ^2

*3. Show that if true for k, true for k+1.

    SUM3(k + 1) =  ( 2 | k(k+1) ) ^2  + (k+1)^3
                       =  ( 2 | k^2 + k ) ^2 + (k+1)^3
                       =  ( 2 | k+1(k+2) ) ^2 =  ( 2 | k^2 + 3k + 2) ^2


    SUM3(k+1) = SUM3(k) + (k+1)^3

    ( 2 | k(k+1) ) ^2


3. Prove by induction that the sum 1 + 3 + 5 + 7 + ... + 2n-1 is n^2; e.g. // not sure on this one...please advise.
for n=3, 1 + 3 + 5 = 3^2

        1 + 3 + 5 + ... + (2n - 1) = n^2
        Assume true for sample n;

        1 + 3 + 5 + ... + (2n - 1) - 2(n - 1) = (n - 1)^2

        n^2 - 2(n - 1) = (n - 1)^2
        n^2 - 2n + 2 - 1 = n^2 - 2n +1
        n^2 - 2n + 1 = n^2 - 2n + 1

        Since true for n + 1,..true for any n.
0
Comment
Question by:edelossantos
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
5 Comments
 

Author Comment

by:edelossantos
ID: 12157932
Please advise on #3.  Del
0
 
LVL 9

Accepted Solution

by:
jhshukla earned 500 total points
ID: 12158005
>> ANSWER: 5
>> 321   312   231   213   123

NO! Answer: 6
321   312   231   213   123   132
this may b because i did not understand how you permute using stack.

and this is not a math room. anyways since most comp sci people like math this is a good place to seek answers.
1 + 3 + 5 + 7 + ... + 2n-1 is n^2
next number in the series is 2(n+1)-1; substituting (1 + 3 + 5 + 7 + ... + 2n-1) = n^2 the series becomes
n^2 + 2(n+1)-1
= n^2 + 2n + 1
= (n+1)^2
THE END
0
 

Author Comment

by:edelossantos
ID: 12162712
sorry... and thanks again for your help.  Truly appreciate it.  Regards.  Del
0
 
LVL 9

Expert Comment

by:jhshukla
ID: 12166068
sorry? for what? you haven't hurt anyone or done anything harmful to this world. plus I love induction. so i thank you for asking.
0
 
LVL 9

Expert Comment

by:jhshukla
ID: 12166536
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Often, when implementing a feature, you won't know how certain events should be handled at the point where they occur and you'd rather defer to the user of your function or class. For example, a XML parser will extract a tag from the source code, wh…
Many modern programming languages support the concept of a property -- a class member that combines characteristics of both a data member and a method.  These are sometimes called "smart fields" because you can add logic that is applied automaticall…
The viewer will learn how to use the return statement in functions in C++. The video will also teach the user how to pass data to a function and have the function return data back for further processing.
The viewer will learn how to user default arguments when defining functions. This method of defining functions will be contrasted with the non-default-argument of defining functions.

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question