Week 11 - Understanding Programming Difficulties

Prior to Small Group

The work this week is being done in a slightly different order. In most sections I have you READ first and then WRITE second. In this section I want to reverse those. I want you to think about the problem before the "experts" tell you what they think The end goal of this topic is for each participant to possess an annotated list of common programming errors. The annotations should include names and explanations that provide understanding and alternatives for "fixing" them. I firmly believe that by the process of developing this list (in addition to the actual finished product) will enhance both your understanding of programming and your ability to respond to student difficulties.

Write

Your first task is to individually identify difficulties that a novice programmer might encounter. You may remember some that you have encountered. You can, of course, examine your email conversations with instructors or review the videos from Fundamentals of Programming to identify additional ones. You may use whatever format seems most useful to you, but I recommend including name, error message (for syntax errors) or difficulty (for logic errors), cause(s) of the problem, and fix(es) for the problem. Note: syntax errors will have error messages and logic errors will not.

Sample items are included below.



 

Research Readings

I asked you to think through your experiences first because I wanted you to put your own personal experiences on this material. Once you have a good starting list that comes from your own experiences, I want you to do some reading on what the "research literature" has identified as some of the common difficulties that new programmers have when learning how to program.

The list below is not a full assigned reading list.  That is, I do not expect you to read every last detail in each of these papers.  Instead, I would ask you to "browse" these three resources to start with so you understand what they are about. Don't worry about the details. Get the big picture first:

 

Once you have done this I would ask you to REVISIT each one focusing in more detail on the sections pointed out below:

 

 

At the Small Group

At the meetup this week you should

 

After Small Group

 

Weekly Code