Competitive/Collaborative Programming Class

ICPC Computer Programming Contest Prep

Problem Solving in Computer Science

Spring 2012 -- CSC 2700 Section 04

[Isaac's Home Page ]  [Mailing List ]  [Class Page ]  [Normal ]  
 Home
 Outline/Policy
 Summary
 Approach
 References
 
 Homework
   View
   Upload
 
 Problems:
   Archive
   Categories
   Guidelines
 
 Coding
   Tips
 
 Contests:
   Deloitte
 
 Extra:
   Grades
 
 
 
 Class:
   CSC 2700 Section 04
   Tureaud 109
   Tuesday
   5:30 PM - 7:30 PM
 
 Previous:
   2011 Fall
 

Summary

Return to Class Main Page


Class 00: 17-January-2012

  • No new poeople -- bummer. So no need to introduce myself or cover class rules...
  • We do have Deloitte Contest coming up:
    • Feb 25
    • Reg deadline Feb 3
    • Need to pick teams (1-3)
    • Need to determine how to get there (carpool or request funds for van rental)
    • Deloitte Contest Web Site
  • Talked a little about ACM
  • Discussed if class start tiem should move to 5:30 PM
  • problems discussed:

Return to Class Main Page


Class 01: 24-January-2012

  • Did have some new folks -- very briefly covered rules.
  • We do have Deloitte Contest coming up:
    • Feb 25
    • Reg deadline Feb 3
    • Need to pick teams (1-3) BY NEXT CLASS
    • Need to determine how to get there (carpool or request funds for van rental)
    • Deloitte Contest Web Site
  • Problems discussed:

Return to Class Main Page


Class 02: 31-January-2012

  • Teams chosen for Deloitte Contest -- see Deloitte Contest Info for team info.
  • The topic for today was Flood Fill
    • Wikipedia link
    • I explained the flood fill with the example of pouring a liquid (chocolate suace) on to a surface (bowl of ice cream)
    • We started with simple problems that could be solved with flood fill and moved toward more difficult ones.
    • I stepped through my solution for problem572 - Oil Deposits.
    • General ideas about flood fill:
      • You need a way to determine what cells are "adjacent" to your current location. Simple examples include left, right, up, down or the the 8 pixels around a center one in a square grid. But the idea extends easily to anything (3D - 532 - Dungeon Master, hexes - 260 - Il Gioco dell'X ...).
      • You also need to decide whether to do breadth first or depth first. Depth first can be implemented with a very simple recursive method:
        fill(int x, int y)
         BEGIN
            map(x,y) = FULL
            FOR x1,y1=neighborOf(x,y)
                if (EMPTY == map(x1,y1))
                    fill(x1,y1)
         END
        
        This method will look to the first neighbor and if it is empty, it will call fill with that neighbor. This results in filling in one direction as far as possible, and then backing out of the recursion.
    • The flood fill can also be used to solve mazes. If you were to not merely mark the spots as full, but marked them with a distance, you could find the optimal answer. Take the following conditions:
      • empty spots have a 0
      • Walls have a negative value
      Consider this code:
      fill(int x, int y, int level)
       BEGIN
          map(x,y) = level
          level = level + 1
          FOR x1,y1=neighborOf(x,y)
              if ((0 == map(x1,y1)) OR (level < map(x1,y1))
                  fill(x1, y1, level)
       END
      
      This algorithm should work. Whatever value is stored in the goal position after it completes is the minimum number of steps.

      The problem with this algorithm is that it will often have to redo steps. The code level < map(x1,y1) accomplishes the backtracking by replacing longer paths with shorter ones.

      This is a drawback of a depth first approach. If we do breadth first, we should avoid this problem (look at all neighbors of the current point before going on to the next point). To do this, we are going to have to make a FIFO queue to store neighbors in.

      fill(int x, int y, int level)
       BEGIN
          level = level + 1
          FOR x1,y1=neighborOf(x,y)
              if (0 == map(x1,y1))
                  map(x1,y1) = level
                  enqueue(x1, y1)
          WHILE NOT EMPTY(queue)
              x1,y1 = dequeue()
              fill(x1, y1, map(x1, y1))
       END
      
      By setting all the values of all the neighbors, before processing any of the neighbors, you should eliminate the need for backtrack.
  • Problems discussed:

Return to Class Main Page


Class 03: 7-February-2012

  • Contest at Deloitte coming up
    • Talked about approach to contest
    • Time/Computer allocation
    • How as you tire it becomes difficult to start a problem from scratch, so it may be advisable sacrifice time up front and develope "solutions" for all problems you intend to solve
    • Mentioned value in typing in stubs and creating directory structure to hold each problem. My approach would be:
      • Make a directory for each problem
      • Possibly put a stub in each directory, certainly type in a stub that can be copied
      • Use free time to type in input data for each problem (at least the ones that you are planning to try)
    • Discussed taking a stapler and bursting the problem set to individual problems. COnsider taking a notebook or folders to organize with
    • Always print what you have when you leave the keyboard
    • Consider breaking each problem into pieces
      • Basic stub
      • Get data read in
      • Dump routine to ensure data was loaded correctly
      • Solve problem
    • I referred to the Approach web page to show some ideas related to approaching a programming contest. This page has been updated a lot. You should visit it again.
    • Then did a VERY brief overview of Floyd-Warshall Algorithm.
    • Here are the basic steps:
      • Algorithm calculates shortest path between each pair of points
      • Build an adjacency matrix
      • Run algorithm on matrix
      • Look up answer
    • Algorithm can be modified to display actual path for each best answer)
    • Dynamic programming - calculated knowledge retained for later use avoiding redundant computation
  • Problem discussed:

Return to Class Main Page


Class 04: 14-February-2012

  • Contest at Deloitte coming up
    • Once more discussed the upcoming contest
    • Revamped Approach web page
  • Problem discussed:

Return to Class Main Page


Class contest: 25-February-2012

  • Nice uneventful ride to Hattiesburg (after late start)
  • Food was good
  • I was able to compete (started late, talked a lot), solved 3 problems

Return to Class Main Page


Class 05: 28-February-2012

  • Covered the Deloitte Contest problem set
  • Refer to Deloitte Page for the problem set.

Return to Class Main Page


Class 06: 6-March-2012

  • Discussed Programming as an art or a science
  • Covered several stories

Return to Class Main Page


Class 07: 13-March-2012

  • Greedy Algorithms
    • Mandatory Wikipedia definition of Greedy Algorithm
    • My definition: an algorthm that takes the best current choice at all times
    • Classic example: Making change

Return to Class Main Page


Class 08: 20-March-2012

  • Discussed software distribution, what percentage a publisher gets.
  • Number Theory
  • Problem discussed:

Return to Class Main Page


Class 09: 27-March-2012

Return to Class Main Page


Class 10: 3-April-2012

  • Vim Intro - spent some time on VIM. Covered the basics.
  • ACU Contest 2 review

Return to Class Main Page


Class 11: 17-April-2012

  • Upcoming events:
    • Register for class -- 6 folks so far
    • April 19 -- Election Meeting
    • April 26 -- ACM/IEEE BBQ
    • April 27 -- third ACU contest
    • May 1 -- Final
  • Timeline for next Regional:
    • Summer practices - continue on Tuesday night
    • Aug 20 - classes begin
    • Aug 21 - first contest class
    • Aug 28 - second contest class
    • Sep 1 - North Texas Football Game (home)
    • Sep 3 - Labor Day Holiday
    • Sep 4 - third contest class
    • Sep 8 - Washington Football Game (home)
    • Sep 11 - fourth contest class
    • Sep 14 - teams picked
    • Sep 15 - Idaho Football Game (home)
    • Sep 22 - Auburn Football Game (away)
    • Sep 22 - practice contest (tentative)
    • Sep 29 - Towson Football Game (home)
    • Oct 6 - Florida Football Game (away)
    • Oct 6 - practice contest (if Sep 22 does not work)
    • Oct 13 - South Carolina Football Game (home)
    • Oct 18-19 - Fall Holiday
    • Oct 19-20 - tenative date for regional (maybe 27)
    • Oct 20 - Texas A&M Football Game (away)
  • How do you get better?
    • As an individual?
      • Solve more problems at UVA
      • Solve problems systematically (by category)
      • Study things like Algorithms book, Programming Challenges, ...
      • Study math
      • practice editing, syntax, debugging
      • study libraries
      • Show someboady else
      • develop templates
      • develop a library
      • arithmetic
    • As a team?
      • Solve problems with others
      • compete
      • solve problems jointly with others
      • discuss problems
      • look at other peoples' code
    • What other skills can you improve?
      • Linux skills
      • vi/emacs
      • debuggers
      • IDEs (eclipse, ...)
      • svn?
      • Other languages (python, perl, php, C, C++, ...)

Return to Class Main Page


Class 12: 24-April-2012

Return to Class Main Page


Class 13: 1-May-2012

Return to Class Main Page

The statements and opinions included in these pages are those of only. Any statements and opinions included in these pages are not those of Louisiana State University or the LSU Board of Supervisors.
© 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Isaac Traxler