I was trying to work this through recursion, I'm not exactly sure if I got it right. but I think I'm on the right track, since it seems that the greatest sum usually consists of a 3 and/or 2's.
def great_mult(num):
lists = []
if num <= 3:
lists.append(num)
return lists
if num % 3 == 0:
num = (num - 3)
lists.append(3)
lists.extend(great_mult(num))
else:
num = (num - 2)
lists.append(2)
lists.extend(great_mult(num))
return lists
It's nice to finally have some time to try the problems shown in class.
Friday, 5 April 2013
Free Lunch
Understanding the Problems:
Free lunch consists of a group of friends trying to determine who gets free lunch. The way they decide is that they arrange themselves in a circle and start counting the positive natural numbers in order. The person at the most north of the circle starts counting from 1. Anyone who says an even natural number gets removed from the circle. When we reach the last person this wraps around and goes back to the person at the beginning. This continues until there is exactly one person left, and this person gets free lunch in the end.
Devise a Plan:
I'm going to perform a few basic examples to help clear out exactly what happens
Carry out the Plan:
So a few examples to help clear out what happens in different situations, I left the index underneath and used a list because I was preparing it so that I could code it easily later on. The case below, is just a simple example without any complications.
[1, 2, 3, 4]
(0, 1, 2, 3) - Index
[1, 3]
(0, 1) - Index
[1] - Last One = 1
Here there is no complication in reaching the person who gets free lunch since the number of people stays even until you reach the last person. You just continuously remove the person who is at an odd index in python terms.
[1, 2, 3, 4, 5]
(0, 1, 2, 3, 4,) - Index
[5, 1, 3]
(0, 1, 2) - Indes
[3, 5]
(0, 1) - Index
[3]- Last One = 3
Here is were it gets a bit more tricky, since the last item is on an even index, (the number of people is odd) and is right after someone who gets removed. For the python code to work that person becomes the technical new "first person" and we start counting from them. That is why the 5 moves to the front and then the 3 gets moved to the front, since the lists are odd.
def remove_odd_index(L):
''' Remove the odd indeces, which corrolate to the "person"
counting the even natural numbers.
# Once the list has a length of 1 return that item, which means once theres only one person left,
# you have the winner.
if len(L) == 1:
return L[0]
# Go through all the odd indices and remove them.
work = L[:]
for i in range(1, len(L), 2):
work.remove(L[i])
# If there is now an odd number of people then the last person because the first
# in the new "set" of people
if len(L) % 2 != 0:
work.insert(0, L[-1])
work = work[:-1]
# Continue calling the function until there is one person left
return remove_eve_ind(work)
Look Back:
I tried doing it with circles and it made it harder to actually see the pattern when dealing with certain numbers of people, such as the pattern of how to deal with even number of people and the pattern that there is when dealing with an odd number of people. It took me a little while to figure out how to insert the last item at the front of the list, and had a lapse in brain power trying to remember that I could just slice the list to remove the last item, but that was just some rustiness in coding. The general concept of the problems I understand when I kept it as a line because it was easier to see that I could just move the last person in an odd numbered list to the front and continued from there.
I also want to thank Mandy from http://mandyxu.blog.com for showing me this problem, it was actually pretty fun to figure it out the code for this.
Free lunch consists of a group of friends trying to determine who gets free lunch. The way they decide is that they arrange themselves in a circle and start counting the positive natural numbers in order. The person at the most north of the circle starts counting from 1. Anyone who says an even natural number gets removed from the circle. When we reach the last person this wraps around and goes back to the person at the beginning. This continues until there is exactly one person left, and this person gets free lunch in the end.
Devise a Plan:
I'm going to perform a few basic examples to help clear out exactly what happens
Carry out the Plan:
So a few examples to help clear out what happens in different situations, I left the index underneath and used a list because I was preparing it so that I could code it easily later on. The case below, is just a simple example without any complications.
[1, 2, 3, 4]
(0, 1, 2, 3) - Index
[1, 3]
(0, 1) - Index
[1] - Last One = 1
Here there is no complication in reaching the person who gets free lunch since the number of people stays even until you reach the last person. You just continuously remove the person who is at an odd index in python terms.
(0, 1, 2, 3, 4,) - Index
[5, 1, 3]
(0, 1, 2) - Indes
[3, 5]
(0, 1) - Index
[3]- Last One = 3
Here is were it gets a bit more tricky, since the last item is on an even index, (the number of people is odd) and is right after someone who gets removed. For the python code to work that person becomes the technical new "first person" and we start counting from them. That is why the 5 moves to the front and then the 3 gets moved to the front, since the lists are odd.
def remove_odd_index(L):
''' Remove the odd indeces, which corrolate to the "person"
counting the even natural numbers.
# Once the list has a length of 1 return that item, which means once theres only one person left,
# you have the winner.
if len(L) == 1:
return L[0]
# Go through all the odd indices and remove them.
work = L[:]
for i in range(1, len(L), 2):
work.remove(L[i])
# If there is now an odd number of people then the last person because the first
# in the new "set" of people
if len(L) % 2 != 0:
work.insert(0, L[-1])
work = work[:-1]
# Continue calling the function until there is one person left
return remove_eve_ind(work)
Look Back:
I tried doing it with circles and it made it harder to actually see the pattern when dealing with certain numbers of people, such as the pattern of how to deal with even number of people and the pattern that there is when dealing with an odd number of people. It took me a little while to figure out how to insert the last item at the front of the list, and had a lapse in brain power trying to remember that I could just slice the list to remove the last item, but that was just some rustiness in coding. The general concept of the problems I understand when I kept it as a line because it was easier to see that I could just move the last person in an odd numbered list to the front and continued from there.
I also want to thank Mandy from http://mandyxu.blog.com for showing me this problem, it was actually pretty fun to figure it out the code for this.
Monday, 1 April 2013
Computable Halt! ...... never mind
I found this concept so strange, the way we prove a function is not computable is by assuming it is computable and showing that it is a halting function and since a halting function is not computable then we can safely assume that our original function is not computable.
I find a lot of these concepts strange but I understand why the proof structure works. If something can't exist then you can't really say it does within your function.
After the assignment I was doing one of the tutorial problems, which was pretty similar to the assignment and it helped clear up some of the stuff that I was unsure of.
Here's how I did it.
Reduce halt to allstop.
all stop(P) = { True if P(x) halts for every input x,
{ False, otherwise'
def half(P, x):
def all stop(P):
#Check if P(x) halts
# for every input X
# Assume computable
def not_f(x)
P(x)
return "You shall halt"
return all stop(not_f, x)
The way I explained it to complete the proof was that if P(x) halted, that meant not_f(x) halts, which causes allstop(P) to return True. In the end this means that halt returns True as well. If P(x) doesn't halt, then not_f(x) doesn't halt which means allstop(P) would return False, which would cause the halting function to return False. So when P(x) halts, allstop returns True and halt(P, x) returns True and when P(X) doesn't halt, then allstop returns False and halt(P, x) returns False. So This means I have technically written a working halting function, which doesn't exist to my knowledge. So then we can safely assume that allstop is not computable since it is a halting function.
I hope that explanation makes sense, took a bit of explanation from my assignment partner for it to make sense of it when we were working on the assignment.
I find a lot of these concepts strange but I understand why the proof structure works. If something can't exist then you can't really say it does within your function.
After the assignment I was doing one of the tutorial problems, which was pretty similar to the assignment and it helped clear up some of the stuff that I was unsure of.
Here's how I did it.
Reduce halt to allstop.
all stop(P) = { True if P(x) halts for every input x,
{ False, otherwise'
def half(P, x):
def all stop(P):
#Check if P(x) halts
# for every input X
# Assume computable
def not_f(x)
P(x)
return "You shall halt"
return all stop(not_f, x)
The way I explained it to complete the proof was that if P(x) halted, that meant not_f(x) halts, which causes allstop(P) to return True. In the end this means that halt returns True as well. If P(x) doesn't halt, then not_f(x) doesn't halt which means allstop(P) would return False, which would cause the halting function to return False. So when P(x) halts, allstop returns True and halt(P, x) returns True and when P(X) doesn't halt, then allstop returns False and halt(P, x) returns False. So This means I have technically written a working halting function, which doesn't exist to my knowledge. So then we can safely assume that allstop is not computable since it is a halting function.
I hope that explanation makes sense, took a bit of explanation from my assignment partner for it to make sense of it when we were working on the assignment.
Thursday, 21 March 2013
Clarifying Big-Oh
Big-Oh notation was a weird concept to me at first, especially when Professor Heap told us that we could just choose to drop values from within the given functions. But after going through the steps it started to make a lot more sense.
Since we are saying that the function that we are making bigger is bounded above by a function that we are making smaller, even if we only have to multiply by a small constant factor. If it is true for that then it is true for all natural number.
Here's a run through from one of the tutorial examples:
Statement: ∃c ∈ R, ∃B ∈ ℕ, ∀n ∈ ℕ, n ≥ B ⇒ 5n4 - 3n2 + 1 ≤ c(6n5 – 4n3 + 2n)
Since we are saying that the function that we are making bigger is bounded above by a function that we are making smaller, even if we only have to multiply by a small constant factor. If it is true for that then it is true for all natural number.
Here's a run through from one of the tutorial examples:
Statement: ∃c ∈ R, ∃B ∈ ℕ, ∀n ∈ ℕ, n ≥ B ⇒ 5n4 - 3n2 + 1 ≤ c(6n5 – 4n3 + 2n)
Pick c = 3, Then c
∈ R
Pick B = 1, Then B ∈ ℕ
Assume n ∈ ℕ # n is a generic
natural number, to introduce ∀
Assume n ≥ B # assume antecedent, to
introduce ⇒
Then 5n4 - 3n2 + 1
- Since we're saying that 5n4 - 3n2 + 1 is bound above by c(6n5 – 4n3 + 2n) we can continue to make it larger and if it is still bound above then we know it is true.
≤ 5n4 + 1 #
Remove (-3n)
- For all the natural numbers past the break point, we can safely prove that this will be bound above by this.
≤ 5n4 + n # n ≥ 1 hence B = 1
=
5n4 +
n4
= 6n5 #
Multiply by n
- Here we pick the c, so that this function is true for all natural numbers N. c this helps scale the function to make this true for all natural numbers.
= 3(2n5) #
c = 3
=
c(6n5 – 4n5)
≤ c(6n5 – 4n3)
≤ c(6n5 – 4n3 + 2n)
- Since c(6n5 – 4n3 + 2n) is what we are bounding by we can continue to make it smaller for the same reason stated above, because if this still bounds the bottom function above then it is true for the much larger function.
Then
5n4 - 3n2 + 1 ≤ c(6n5 – 4n3 + 2n)
Then n
≥ B ⇒ 5n4 - 3n2 + 1 ≤ c(6n5
– 4n3 + 2n) # conclude ⇒
Then ∀n ∈ ℕ,
n ≥ B ⇒ 5n4 - 3n2 + 1 ≤ c(6n5
– 4n3 + 2n) # conclude
∀
Then ∃c ∈ R,
∃B ∈ ℕ, ∀n ∈ ℕ,
n ≥ B ⇒ 5n4 - 3n2 + 1 ≤ c(6n5
– 4n3 + 2n) # conclude ∃
Wednesday, 20 March 2013
Test and Assignments !
Just got my test and assignment mark back and I'm extremely happy with how it turned out. As I stated in my previous post, the assignments do really help in preparing for the test. Of course reviewing the past test and reading all the lecture notes over also helped while also practicing everything we covered in tutorial and lectures to make sure I got down the concepts. It's strangely satisfying reaching the end of a proof and understanding why it makes sense.
Now we're moving on from that and going into Assignment 3, which I believe will cover much of what we have seen of Chapter 4. I think I'm ready for the challenge. I'm still a bit unsteady on some of the ideas of Chapter 4 like how we can just remove certain elements of a function. I understand why we do it, but it just seems strange. I think I'm to use to Calculus we're we can't just make things disappear.
Now we're moving on from that and going into Assignment 3, which I believe will cover much of what we have seen of Chapter 4. I think I'm ready for the challenge. I'm still a bit unsteady on some of the ideas of Chapter 4 like how we can just remove certain elements of a function. I understand why we do it, but it just seems strange. I think I'm to use to Calculus we're we can't just make things disappear.
Wednesday, 13 March 2013
Progress
It's weird but every time I learn something new in this class I find it extremely hard and feel doomed, but after practicing a bit here and there things seem to work out. The way this course is structured works out pretty well. In the sense that the Assignments help develop the skills i need to do well on the Tests. This and the steady pace keeps this, I find, at a manageable pace.
The slog has been a little slow lately and I'm sorry for that. Just keeping up with the assignment and preparing for the tests take up a lot of time.
The slog has been a little slow lately and I'm sorry for that. Just keeping up with the assignment and preparing for the tests take up a lot of time.
Thursday, 7 March 2013
StreetCar Drama is possible
When I had heard Professor Heap telling us about the street car problem, I didn't think it was possible but it seems it is. I was reading my friend Mandy's blog and she had figured it out. The solution can be found here: http://mandyxu.blog.com/2013/02/28/streetcar-drama/
Heres the problem:
A: Haven't seen you in a long time! How old are your three kids now?
B: The product of their ages (rounded down to the nearest year) is 36.
A: That doesn't really answer my question.
B: Well, the sum of their ages is (fire engine goes by)
A: That still doesn't tell me how old they are.
B: Well, the eldest plays piano.
A: Okay, I see: their ages are (you have to get off the streetcar)
Heres the problem:
A: Haven't seen you in a long time! How old are your three kids now?
B: The product of their ages (rounded down to the nearest year) is 36.
A: That doesn't really answer my question.
B: Well, the sum of their ages is (fire engine goes by)
A: That still doesn't tell me how old they are.
B: Well, the eldest plays piano.
A: Okay, I see: their ages are (you have to get off the streetcar)
The solution is actually pretty clever and the one tip that I can give without pretty much giving the answer a away is to write out the possible combinations of numbers. It always seems that carrying out a few sample solutions helps find patterns in this course.
Saturday, 2 March 2013
Proofs!
Working on the assignment after a busy week, I found the most challenging one to be question #6 to be one of the more challenging ones. It was hard to see how all the pieces fit together even when you have everything you need in front of you.
Though in the end it worked out, not it's more about organizing the structure and having appropriate comments which is kind of hard to determine. It's hard to decide what a good comment is for a proof and what is just starting the obvious.
Though in the end it worked out, not it's more about organizing the structure and having appropriate comments which is kind of hard to determine. It's hard to decide what a good comment is for a proof and what is just starting the obvious.
Monday, 18 February 2013
Diagonals - Square Madness
I ended up doing the Diagonals work sheet today just because I wanted to see if I could figure out the answer, and I thought I did for a second until I tried a larger number of rows and columns
In class I thought I had figured it out but that was because of the way that I had gone about trying to solve it. I was doing random sample squares with varying rows and columns which doesn't help to see any patterns. I still haven't figured it out since my answer seems to only work up to a certain size of square. This is just kind of a way to see the process I took for the next time I look at the problem.
The Steps:
Understand the Problem:
Find a mathematical expression that can determine the number of shaded squares
Devise a Plan:
When nothing works, looking for a pattern always gives some inkling of information. So here I just did a systematic approach of drawing squares keeping the rows constant and changing the columns. During class the issue I had in class was that we didn't keep a constant row or column so we didn't see what was staying constant throughout.
Carry out the Plan:
In class I thought I had figured it out but that was because of the way that I had gone about trying to solve it. I was doing random sample squares with varying rows and columns which doesn't help to see any patterns. I still haven't figured it out since my answer seems to only work up to a certain size of square. This is just kind of a way to see the process I took for the next time I look at the problem.
The Steps:
Understand the Problem:
Find a mathematical expression that can determine the number of shaded squares
Devise a Plan:
When nothing works, looking for a pattern always gives some inkling of information. So here I just did a systematic approach of drawing squares keeping the rows constant and changing the columns. During class the issue I had in class was that we didn't keep a constant row or column so we didn't see what was staying constant throughout.
Carry out the Plan:
Monday, 4 February 2013
Sorry for the delayed post, after going through with the assignment had a lot of things to catch up on over the weekend especially with the upcoming tests.
Anyways, this week we started delving deeper into proofs and so far it's seems really new to me though I haven't had time to look deeper into the notes for Chapter 3.
What I find slightly difficult is being able to decide which steps to do to to go from "P" to "Q", and how someone in the end decides which is the most logical step. Though this is bringing back a lot of memories with the left side == right side type of things we did in high school though I'm not sure if thats exactly what we're doing but I'm thinking it is. I'll be making a more detailed post about proofs next week.
Anyways, this week we started delving deeper into proofs and so far it's seems really new to me though I haven't had time to look deeper into the notes for Chapter 3.
What I find slightly difficult is being able to decide which steps to do to to go from "P" to "Q", and how someone in the end decides which is the most logical step. Though this is bringing back a lot of memories with the left side == right side type of things we did in high school though I'm not sure if thats exactly what we're doing but I'm thinking it is. I'll be making a more detailed post about proofs next week.
Saturday, 26 January 2013
Second Week
What a week, grappling with the assignment was a long endeavour. I expected it to be difficult but in a different sense. I found it difficult in the context of how hard it was to be 100% sure an answer was correct. Sometimes interpreting a question one way would make you think of an answer and then the next minute you read it again and it makes you think of a completely different possibility. Many moments feeling stumped and taking a break to clear my mind. I'm looking at you question 3, assignment 1.
Thought after completing the assignment I'm starting to feel more comfortable with the ideas and concepts being taught in the course. Though I still find it difficult in the sense that it's hard to know when I'm right or wrong. It might sound right to me and then it turns out it meant something very similar but different.
Though I'm glad that I'm finally grasping all the symbols and understanding the concepts of negation, contrapositive, and converse. It took me a while to grasp how they worked and how contrapositive had the same meaning as the original statement. I found it really hard to accept the idea of contrapositive, the concept that something that sounded so different from the original could mean the exact same thing. I guess this course just takes some warming up to.
Though I'm glad that I'm finally grasping all the symbols and understanding the concepts of negation, contrapositive, and converse. It took me a while to grasp how they worked and how contrapositive had the same meaning as the original statement. I found it really hard to accept the idea of contrapositive, the concept that something that sounded so different from the original could mean the exact same thing. I guess this course just takes some warming up to.
Monday, 14 January 2013
The Beginning
I wasn't really sure what to expect for this class especially with the title of Mathematical Expression and Reasoning for Computer Science. After the first lecture I was even more confused, mostly when Professor Heap was mentioning that we were here to communicate with precision but not to much precision, and that we would have to adjust the amount of precision to be on par with our peers. I'm assuming this will have more to do with proofs, which I'm also not to familiar with but hopefully will grasp in a good amount of time.
The material we are covering is pretty new to me and I'm finding it somewhat like learning a new language, there are a large chunk of symbols that I'm not to familiar with and knowingly I'll have to cover many to be able to grasp the ideas being taught in class. Though even with the unfamiliarity with the symbols I can understand the message within the lectures about subsets, and proving and disproving existence.
So far this course seems like it will be challenging, hopefully in a good way.
Blogging is pretty new to me so I'm still figuring out a good way to flow through ideas. Hopefully this isn't to broken up.
The material we are covering is pretty new to me and I'm finding it somewhat like learning a new language, there are a large chunk of symbols that I'm not to familiar with and knowingly I'll have to cover many to be able to grasp the ideas being taught in class. Though even with the unfamiliarity with the symbols I can understand the message within the lectures about subsets, and proving and disproving existence.
So far this course seems like it will be challenging, hopefully in a good way.
Blogging is pretty new to me so I'm still figuring out a good way to flow through ideas. Hopefully this isn't to broken up.
Subscribe to:
Posts (Atom)