I felt that discussing some of the pros and cons of this semester's CSC148 is important, so I am going to talk about a few things I liked and some that I did not. The most helpful thing this semester were the exercises in my opinion. They managed to serve as nice refreshers to the course materials for me. However, what I did not like about them is that they were getting marked and there weren't too many of them. I think it would have been better if we were simply given a lot more exercises to work on that were not getting marked. The automarking for the exercises meant that there weren't enough of them to help us understand the course material better. What I think was done really well this semester were both of the assignments and tests, regardless of what most other people say. All of them were fair, yet the right amount of difficulty. What I particularly did not enjoy too much this semester are the SLOGs. I don't feel that they helped me at all with my programming skills. What I think would have been better is to have forum participation instead of SLOGs because then we would actually look at each other's ideas about the course. With different blogs, it is much more difficult to communicate with other people since they all have different SLOG urls.
All in all, bring more exercises Dan. Also, forum participation would be better than blogs in my opinion.
Thursday, 3 April 2014
Wednesday, 2 April 2014
Applying memoization to A1 solver
Ever since we talked about memoization, I have been wondering about how to optimize tour_of_four_stools method in Assignment 1, tour.py file. My original approach was to use a method which would generate the lowest k value for the function, k being a number that gives the lowest number of moves for the equation : [2*k - 1 + 2*tour_of_four_stools(n - k)]. When I was doing preliminary testing that would calculate the optimal number of moves, I was able to reach up to a million cheeses and it would still calculate the answer in a second. However, when I actually implemented it in the assignment, it would not calculate the moves after 1000 cheeses. I was initially thinking of a bottom up approach, but it was actually less efficient than my recursive approach. Of course, I wasn't using the function which actually sped things up for my recursive tour_of_four_stools method, which is the generate_lowest_k function.
Now, generate_lowest_k generated a list of k values for the equation mentioned previously such that the number at index (k-1) of the list lowest_k would be the optimal k for the lowest number for that equation. The pattern being 1,1,2,2,2,3,3,3,3... and so on. Now, I thought of two approaches of possibly speeding up tour_of_four_stools function. The first is to generate all the answers from 1 to n and just use lowest_k to pick the ideal two numbers from two separate lists, one for 2*k - 1, and the other from 2*tour_of_four_stools(n - k). 2*k - 1 list will be of length k to make things more efficient and the other will be of length (n - k). I am going to think of some more ways of optimizing this algorithm as I am not completely convinced that this will be faster than my previous approach.
Now, generate_lowest_k generated a list of k values for the equation mentioned previously such that the number at index (k-1) of the list lowest_k would be the optimal k for the lowest number for that equation. The pattern being 1,1,2,2,2,3,3,3,3... and so on. Now, I thought of two approaches of possibly speeding up tour_of_four_stools function. The first is to generate all the answers from 1 to n and just use lowest_k to pick the ideal two numbers from two separate lists, one for 2*k - 1, and the other from 2*tour_of_four_stools(n - k). 2*k - 1 list will be of length k to make things more efficient and the other will be of length (n - k). I am going to think of some more ways of optimizing this algorithm as I am not completely convinced that this will be faster than my previous approach.
Tuesday, 1 April 2014
Exam tips
Exam time is coming up. Since CSC148 is a drastically different course from any others, studying techniques are also drastically different for it. It isn't enough to just memorize everything, if at all useful, but to have a deep understanding of how certain programming techniques work. An effective strategy for any course would be to look at the past exams, but even that might not work too well for computer science since even the curriculum is very dynamic from one year to another. In my opinion, the best way to study for a computer science exam is to do the assignments over again as efficient as possible. This will make you think of how to use things that were learned during the year. Also, I find reviewing the labs to be really helpful because it might be a completely different experience doing the labs by yourself compared to doing it in a group. If possible, challenge yourself by trying to get your programs correct the first few times (for labs and exercises that is) because obviously you will not have a computer to test stuff on during the exam. Those were my exam tips and I hope they help out whoever reads them.
Subscribe to:
Posts (Atom)