Problem 2 Motivation In computer science, we often use induction to prove the correctness of a function - that is, we prove formally that the function does what it is supposed to do. This is sometimes called "proving a function." For example, consider the Python function below, which reverses an input string using recursion. def reverse_string(s): |||||| reverse the string s. The first letter becomes the last letter, the second letter becomes the second- args: s, the string to be reversed returns: the reversed string if s == ""; return "" else: return reverse_string(s [1:])+s[0] Here it is in action. reverse_string("CSCI 0200") ¹0020 ICSC' We got the right answer for this input! But...would we get the right answer on every possible input? Let's write a proof which will guarantee that we will.
Solve Problem 2 by using an induction.
![Problem 2
Motivation
In computer science, we often use induction to prove the correctness of a function - that is, we prove formally that the function does
what it is supposed to do. This is sometimes called "proving a function." For example, consider the Python function below, which
reverses an input string using recursion.
def reverse_string(s):
||||||
reverse the string s. The first letter becomes the last letter, the second letter becomes the second-
args:
s, the string to be reversed
returns: the reversed string
||||||
if s == "":
return
else:
return reverse_string(s[1:]) + s [0]
Here it is in action.
||||
reverse_string ("CSCI 0200")
¹0020 ICSC'
We got the right answer for this input! But...would we get the right answer on every possible input? Let's write a proof which will
guarantee that we will.
0
C](/v2/_next/image?url=https%3A%2F%2Fcontent.bartleby.com%2Fqna-images%2Fquestion%2F385eb8fb-6648-4df6-8047-4f830c46ad3b%2F7ca56bff-40a0-41b2-ab16-2b883adf027a%2Fckokcln_processed.png&w=3840&q=75)
data:image/s3,"s3://crabby-images/0e643/0e6437585e92c3692b500ac23e76b5f6268eec69" alt="Problem Statement
We'll write a string with n characters as $₁8283 · Sn-2Sn-1Sn.
Now we can state the thing we want to prove:
Proposition: For any n E N, the result of calling the function reverse_string on the string $18283
of s, that is, the string SnSn-15n-2 · · S3S2S1.
Prove this claim using induction.
Note: The empty string € is the string with no elements at all; this string is its own reversal.
Sn-2Sn-1Sn is the reversal"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
At the base case, let us consider an empty string and a one letter character.
I.e., when n = 0,
Then s = " "
So, its reverse is " ", which is returned by the function as well by its definition.
Again, when n = 1,
Then s = some single character string, say "a".
Then, its reverse is also "a", which we can write as s[0] + " " = s[0] + reverse_string(" ")
= s[0] + reverse_string(s[1:])
Here, s[1:] = " ", as s is a single character string.
Hence, we see, the function reverses a string for n = 0, 1 successfully.
Let us assume, the function reverses a string of length k for some k > 0.
i.e., let, s = s1s2s3............sk-1sk
[ here each si is some character ]
Then, reverse_string(s) = sksk-1............s3s2s1
Step by step
Solved in 3 steps with 1 images
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/459cf/459cf6241d135de10054da228a1eeba40b2fb92a" alt="Advanced Engineering Mathematics"
data:image/s3,"s3://crabby-images/1fad9/1fad99a5e283e74e984c6bf7510d1f9836377e96" alt="Numerical Methods for Engineers"
data:image/s3,"s3://crabby-images/5a87c/5a87cace12f9cc506b7a6251c6c030791d2a058d" alt="Introductory Mathematics for Engineering Applicat…"
data:image/s3,"s3://crabby-images/459cf/459cf6241d135de10054da228a1eeba40b2fb92a" alt="Advanced Engineering Mathematics"
data:image/s3,"s3://crabby-images/1fad9/1fad99a5e283e74e984c6bf7510d1f9836377e96" alt="Numerical Methods for Engineers"
data:image/s3,"s3://crabby-images/5a87c/5a87cace12f9cc506b7a6251c6c030791d2a058d" alt="Introductory Mathematics for Engineering Applicat…"
data:image/s3,"s3://crabby-images/21a4f/21a4f62f7828afb60a7e1c20d51feee166b1a145" alt="Mathematics For Machine Technology"
data:image/s3,"s3://crabby-images/e1ae4/e1ae4278513a956743faa46779d19ccf451bd689" alt="Basic Technical Mathematics"
data:image/s3,"s3://crabby-images/3ba18/3ba18d7401cedc0b368d26ff888192ad5881f9c0" alt="Topology"