AP Computer Science A
Advanced Placement Computer Science A is an AP Computer Science course and examination offered by the College Board to high school students as an opportunity to earn college credit for a college-level computer science course. AP Computer Science A is meant to be the equivalent of a first-semester course in computer science. The AP exam currently tests students on their knowledge of Java.
AP Computer Science AB, which was equivalent to a full year, was discontinued following the May 2009 exam administration.
Course content
AP Computer Science emphasizes object-oriented programming methodology with an emphasis on problem solving and algorithm development. It also includes the study of data structures and abstraction, but these topics were not covered to the extent that they were covered in AP Computer Science AB. The Microsoft-sponsored program Technology Education and Literacy in Schools aims to increase the number of students taking AP Computer Science classes.Topics covered by the course include:
- Object-Oriented Program Design
- *Program Design
- **Read and understand a problem's description, purpose, and goals.
- **Apply data abstraction and encapsulation.
- **Read and understand class specifications and relationships among the classes.
- **Understand and implement a given class hierarchy.
- **Identify reusable components from existing code using classes and class libraries.
- *Class Design
- **Design and implement a class.
- **Design an interface.
- **Choose appropriate data representation and algorithms.
- **Apply functional decomposition.
- **Extend a given class using inheritance.
- Program Implementation
- *Implementation techniques
- **Methodology
- ***Object-oriented development
- ***Top-down development
- ***Encapsulation and information hiding
- ***Procedural abstraction
- *Programming constructs
- **Primitive types vs. objects
- **Declaration
- ***Constant declarations
- ***Variable declarations
- ***Class declarations
- ***Interface declarations
- ***Method declarations
- ***Parameter declarations
- **Console output
- **Control
- ***Methods
- ***Sequential
- ***Conditional
- ***Iterations
- ***Recursion
- *Java library classes
- Program Analysis
- *Testing
- **Test classes and libraries in isolation
- **Identify boundary cases and generate appropriate test data
- **Perform integration testing
- *Debugging
- **Categorize errors: compile time, runtime, logic
- **Identify and correct errors
- **Techniques: use a debugger, add extra output statements, hand-trace code
- *Understand and modify existing code
- *Extend existing code using inheritance
- *Understand error handling
- **Understand runtime exceptions
- *Reason about programs
- **Preconditions and postconditions
- **Assertions
- *Analysis of algorithms
- **Informal comparisons of running times
- **Exact calculation of statement execution counts
- *Numerical representations and limits
- **Representations of numbers in different bases
- **Limitations of finite representations
- Standard Data Structures
- *Simple data types
- *Classes
- *One-dimensional arrays
- *Two-dimensional arrays
- Standard Algorithms
- *Operations on data structures listed above
- **Traversals
- **Insertions
- **Deletions
- *Searching
- **Sequential
- **Binary
- *Sorting
- **Selection
- **Insertion
- **Mergesort
- Computing in Context
- *Major hardware components
- **Primary and secondary memory
- **Processors
- **Peripherals
- *System software
- **Language translators/compilers
- **Virtual machines
- **Operating systems
- *Types of systems
- **Single-user systems
- **Networks
- *Responsible use of computer systems
- **System reliability
- **Privacy
- **Legal issues and intellectual property
- **Social and ethical ramifications of computer use
Case studies and labs
This practice was discontinued as of the 2014-15 school year and replaced with optional labs that teach concepts.
Case studies (discontinued)
Case studies were used in AP Computer Science curriculum starting in 1994.Big Integer case study (1994-1999)
The Big Integer case study was in use prior to 2000. It was replaced by the Marine Biology case study.Marine Biology case study (2000-2007)
The Marine Biology Case Study was a program written in C++ until 2003, then in Java, for use with the A and AB examinations. It served as an example of object-oriented programming embedded in a more complicated design project than most students had worked with before.The case study was designed to allow the College Board to quickly test a student's knowledge of object oriented programming ideas such as inheritance and encapsulation while requiring students to understand how objects such as "the environment", "the fish", and the simulation's control module interact with each other without having to develop the entire environment independently, which would be quite time consuming. The case study also gives all students taking the AP Computer Science exams with a common experience from which to draw additional test questions.
On each of the exams, at least one free-response question was derived from the case study. There were also five multiple-choice questions that are derived from the case study.
This case study was discontinued from 2007, and was replaced by GridWorld.
GridWorld case study (2008-2014)
GridWorld is a computer program case study written in Java that was used with the AP Computer Science program from 2008 to 2014. It serves as an example of object-oriented programming. GridWorld succeeded the Marine Biology Simulation Case Study, which was used from 2000–2007. The GridWorld framework was designed and implemented by , based on the Marine Biology Simulation Case Study. The narrative was produced by Chris Nevison and Barbara Cloud Wells, Colgate University.The GridWorld Case Study was used as a substitute for writing a single large program as a culminating project. Due to obvious time restraints during the exam, the GridWorld Case Study was provided by the College Board to students prior to the exam. Students were expected to be familiar with the classes and interfaces before taking the exam. The case study was divided into five sections, the last of which was only tested on the AB exam. Roughly five multiple-choice questions in Section I were devoted to the GridWorld Case Study, and it was the topic of one free response question in Section II.
GridWorld has been discontinued and replaced with a set of labs for the 2014-2015 school year.
- Actors
- *The GridWorld Case Study employs an Actor class to construct objects in the grid. The Actor class manages the object's color, direction, location, what the object does in the simulation, and how the object interacts with other objects.
- *Actors are broken down into the classes "Flower", "Rock", "Bug", and "Critter", which inherit the Actor class and often override certain methods. Flowers can't move, and when forced to Act, they become darker. Flowers are dropped by Bugs and eaten by Critters. Rocks are also immobile and aren't dropped or eaten. Bugs move directly ahead of themselves, unless blocked by a rock or another bug, in which case the Bug will make a 45 degree turn and try again. They drop flowers in every space they occupy, eat flowers that are directly on their space of grid, and are consumed by Critters. Critters move in a random direction to a space that isn't occupied by a Rock or other Critter and consume Flowers and Bugs.
- Extensions
- *The Case Study also includes several extensions of the above classes. "BoxBug" extends "Bug" and moves in a box shape if its route is not blocked. "ChameleonCritter" extends "Critter" and does not eat other Actors, instead changing its color to match the color one of its neighbors. "Crab Critter" moves left or right and only eats Actors in front of it, but otherwise extends the "Critter" class.
- *Students often create their own extensions of the Actor class. Some common examples of student created extensions are Warden organisms and SimCity-like structures, in which objects of certain types create objects of other types based on their neighbors. Students have even created versions of the games Pac-Man, Fire Emblem, and Tetris.
- Known issues
- *The version that is available at the College Board website, GridWorld 1.00, contains a bug that causes a SecurityException to be thrown when it is deployed as an applet. This was fixed in the "unofficial code" release on the GridWorld website. Also, after setting the environment to an invalid BoundedGrid, it will cause a NullPointerException.
Labs
- The Magpie Lab
- The Elevens Lab
- The Picture Lab
AP Exam
History
The AP exam in Computer Science was first offered in 1984.Before 1999, the AP exam tested students on their knowledge of Pascal. From 1999 to 2003, the exam tested students on their knowledge of C++ instead. Since 2003, the AP Computer Science exam has tested students on their knowledge of computer science through Java.
Format
The exam is composed of two sections, formerly consisting of the following times:- Section I: Multiple Choice
- Section II: Free-Response
- Section I: Multiple Choice
- Section II: Free-Response
Grade distributions for AP Computer Science A
Score | 2003 | 2004 | 2005 | 2006 | 2007 | 2008 | 2009 | 2010 | 2011 | 2012 | 2013 | 2014 | 2015 | 2016 | 2017 | 2018 | 2019 | 2020 |
5 | 17.1% | 18.6% | 17.9% | 21.9% | 19.3% | 21.7% | 23.2% | 26.3% | 24.9% | 23.6% | 26.6% | 21.3% | 24.4% | 20.7% | 24.4% | 24.7% | 27.0% | 25.2% |
4 | 24.5% | 23.6% | 23.2% | 22.2% | 22.8% | 21.7% | 25.7% | 24.7% | 24.8% | 24.3% | 26.6% | 23.1% | 24.6% | 20.4% | 20.9% | 21.3% | 22.1% | 21.3% |
3 | 19.6% | 15.3% | 14.9% | 14.4% | 14.5% | 13.9% | 13.2% | 13.9% | 14.2% | 15.6% | 13.9% | 16.8% | 15.3% | 23.2% | 21.9% | 21.7% | 20.8% | 22.8% |
2 | 9.2% | 9.4% | 9.9% | 7.7% | 9.5% | 9.0% | 8.2% | 7.9% | 7.9% | 7.7% | 7.0% | 7.7% | 7.1% | 12.5% | 11.5% | 11.8% | 11.8% | 12.9% |
1 | 29.6% | 33.1% | 34.0% | 33.7% | 33.9% | 33.7% | 29.8% | 27.1% | 28.2% | 28.7% | 25.9% | 31.1% | 28.6% | 23.2% | 21.3% | 20.5% | 18.3% | 17.8% |
Mean | 2.90 | 2.85 | 2.81 | 2.91 | 2.84 | 2.89 | 3.04 | 3.15 | 3.10 | 3.06 | 3.21 | 2.96 | 3.09 | 3.04 | 3.16 | 3.18 | 3.28 | |
Students | 14,674 | 14,337 | 13,924 | 14,662 | 15,049 | 15,537 | 16,622 | 20,120 | 22,176 | 26,103 | 31,117 | 39,278 | 48,994 | 57,937 | 60,519 | 65,133 |
AP Computer Science AB
Course content
The discontinued AP Computer Science AB course included all the topics of AP Computer Science A, as well as a more formal and a more in-depth study of algorithms, data structures, and data abstraction. For example, binary trees were studied in AP Computer Science AB but not in AP Computer Science A. The use of recursive data structures and dynamically allocated structures were fundamental to AP Computer Science AB. Due to low numbers of students taking the AP Computer Science AB exam, it was discontinued after the 2008–2009 year.Grade distributions for AP Computer Science AB
The AP Computer Science AB Examination was discontinued as of May 2009. The grade distributions from 2003 to 2009 are shown below:Score | 2003 | 2004 | 2005 | 2006 | 2007 | 2008 | 2009 |
5 | 37.6% | 27.0% | 31.2% | 33.7% | 33.2% | 38.9% | 39.3% |
4 | 13.8% | 18.5% | 19.5% | 19.7% | 19.7% | 19.1% | 20.6% |
3 | 24.6% | 17.8% | 18.5% | 17.2% | 18.3% | 15.1% | 16.1% |
2 | 10.0% | 12.0% | 10.4% | 9.3% | 9.3% | 9.0% | 7.4% |
1 | 13.8% | 24.6% | 20.4% | 20.1% | 19.5% | 18.0% | 16.5% |
Mean | 3.51 | 3.11 | 3.31 | 3.38 | 3.38 | 3.52 | 3.59 |
Students | 7,071 | 6,077 | 5,097 | 4,939 | 5,064 | 4,995 | 3,881 |