AP Computer Science Final Project - Indexing and the Word-Location Trick Indexing Algorithms

Size: px
Start display at page:

Download "AP Computer Science Final Project - Indexing and the Word-Location Trick Indexing Algorithms"

Transcription

1 AP Computer Science Final Project - Indexing and the Word-Location Trick Indexing Algorithms Search engines can sift through tens of billions of web pages and index those pages so that humans can quickly and accurately find pertinent information with the click of a button. How do search engines such as Google perform this magic you ask? In this program, we will write methods that perform simple, yet effective forms of this powerful indexing algorithm*. In the project template, the WebPageProcessor class has a method filetoletters() that reads plain text from a text file (representing a random web page on the net) and places each letter into an ArrayList, one letter per element. For example, if the text in a file page1.txt is: The cat in the hat then filetoletters( page1.txt ) will store each letter (a String of length 1) as one element in an ArrayList of Strings as shown below: Actual HTML formatted web pages are much more complex than a raw text file, but this simple example will give you the basic idea behind the logic of the indexing algorithm. Part A filetoletters() a. Create a plain text file using Word or other word processor and save it as a plain text file called myfile.txt file in the WebpageIndexingProject project folder. In this simple example, only include one line of text with no enter s or return s that would create a second line of text. Keystrokes such as enter and other non-standard characters will be addressed later. b. Edit the WebpageProcessorDriver so that the argument to the method filetoletters() is myfile.txt. c. Run the WebpageProcessorDriver to verify that your file myfile.txt is converted to an ArrayList of Strings by the program. * an additional algorithm, the Ranking Algorithm, is used by Google to rank pages according to their relevance. This algorithm is what separated Google from the rest of the pack.

2 Part B Class WebpageProcessor Class WebpageProcessor contains method letterstopage(). This method will take as its parameter an ArrayList of single letters (i.e. Strings of length 1 in Part A above) and convert it into a ProcessedPage which consists of an ArrayList of words as shown below. ProcessedPage object shown below consists an of ArrayList<String> Since this ArrayList of words represents the words on a webpage, this method will return a ProcessedPage object that has-an ArrayList of these words. As shown above, the result is a ProcessedPage object that contains an ArrayList<String> of length 5 that has one word per element. Examine the ProcessedPage class in the WebpageIndexingProject template. This is a complete class; you do not have to make any changes to this class for this project. Write the WebpageProcessor method letterstopage() that has the method header as shown below: public ProcessedPage letterstopage(arraylist<string> letters) Use the WebpageProcessorDriver to test Part B. Sample output from running the letterstopage method is shown below:

3 Part C searchword A ProcessedPageCollection object consists of an ArrayList of ProcessedPages as shown below. Note that each ProcessedPage object was created using letterstopage() method written in part B. Each of the pages above contains all of the words on its page. Recall that words on a ProcessedPage object are stored internally as an ArrayList<String>. This allows each word to be accessed uniquely via its index. Write the ProcessedPageCollection method searchword that takes a single String search word and returns the page number(s) that the word is found on. See the following examples: Example 1: The result of calling searchword( the ), will return an ArrayList containing the values 0, 1, and 2, since the String the is found on pages 0, 1, and 2. Note that the values 0 and 1 should only appear once although the is found twice on each page. Example 2: The result of calling searchword( sat ), will return an ArrayList containing the values 0 and 2, since the String sat is found on pages 0 and 2. Write the ProcessedPageCollection method searchword that has the method header as shown below: public ArrayList<Integer> searchword( String word )

4 Part D Processing enter keystrokes (extra credit) The WebpageProcessor method filetoletters() does not read lines of text after an enter or return keystroke. Modify the method filetoletters() so that this method can process files that have an enter or return keystroke. Test your solution using the method written in Part C. If your algorithm works correctly, you will be able to verify that all text in the file has been read in correctly and can successfully be found using the searchword method.

5 Part E createindextable() and printindextable() The Word-Location algorithm allows a search engine to quickly locate a phrase from a selection of indexed web pages without having to look at the web pages themselves **. Consider the following set of ProcessedPage objects in a ProcessedPageCollection below: Give the set of pages shown above, an index table was created based on the page and word location within a page for each word on the page as shown below. Note that column numbers correspond to the page a word is found on and the row numbers correspond to the location of the word on that page. The word dog has the entries 1-1 and 2-5 since it appears on (page 1, word 1) and (page 2, word 5.) Examine the indextable shown below to verify that each word and corresponding page-word location in the table are consistent with the words found on pages 0, 1, and 2 above. ** in the actual implementation of this method, index tables are constantly being updated in the background so that successive searches will yield more accurate and relevant search results depending on what web pages are being created and removed from the web. Imagine that this algorithm is running on the web as you read!

6 This part will require you to complete the following: a. Design and include a private instance variable indextable in the ProcessedPageCollection class that is capable of storing a word, page, and word location for each word on a given page. This is the most creative and critical part of the project. When designing this class, keep in mind its purpose and the fact that you will want easy access to the data in the indextable. Write the ProcessedPageCollection method createindextable that has the method header as shown below: public void createindextable() b. Include a method printindextable() that will print all elements in indextable in a 2D array-like format. Write the ProcessedPageCollection method printindextable() that has the method header as shown below: public void printindextable()

7 Part F searchphrase Using the indextable from part E, write the ProcessedPageCollection method searchphrase() that will take two String arguments representing two search keywords and return the most relevant ProcessedPage in the ProcessedPageCollection. The most relevant page is defined as the page that contains the two search keywords that are the closest to one another on a given page. The method searchphrase() has the method header shown below: public ArrayList<Integer> searchphrase( String keyword1, String keyword2 ) This method should implement an algorithm that analyzes the page and word number pairs in the indextable and returns the page(s) that is/are the most relevant. Example 1: searchphrase( cat, sat ) will return an ArrayList containing the integer 0 since this is the page contains cat and sat in the nearest proximity. The words cat and sat also appear on page 2, but they are further apart than they are on page 0. Example 2: searchphrase( the, cat ) will return an ArrayList containing the integers 0, 1 and 2 since these three pages contain the and cat in equal proximity to one another (i.e. the words the and cat and appear one word apart on all three pages. Example 3: searchphrase( dog, stood ) will return an ArrayList containing the integer 1 since this is the page that dog and stood appear on with the nearest proximity (they are one word apart.) Page 2 also contains dog and stood, but they are in further proximity from one another (they are 5 words apart) in addition to being in reverse order. Part G User interface Make your project user-friendly by creating a single JOptionPane dialog box that will ask the user for a search word or words (like a Google search bar.) Your program should use previously written methods to retrieve and display the most relevant search results (i.e. print the text of the page on the screen.) Part H Search Time Include the timer that was used in the Searching and Sorting projects to display how fast your algorithm finds a page (See Appendix A on the next page for this code.) Display the time along with your search results. finalproject.isdone=true;

8 Appendix A Timer Code public class TimerDriver public static void main( String args[] ) Stopwatch seiko = new Stopwatch(); seiko.starttimer(); for(int ctr = 0; ctr < Integer.MAX_VALUE; ctr++) // place the code/algorithm that you wish to time here } seiko.endtimer(); seiko.printelapsedtime(); } // end method main } // end class TimerDriver public class Stopwatch private long starttime; private long endtime; public Stopwatch() starttime = 0; endtime = 0; } // end constructor StopWatch public void starttimer() starttime = System.nanoTime(); } // end method starttimer public void endtimer() endtime = System.nanoTime(); } // end method endtimer public void printelapsedtime() System.out.println( "Elapsed time in nanoseconds is: " + (endtime - starttime)); } // end method printelaspedtime } // end class Stopwatch

Timing ListOperations

Timing ListOperations Timing ListOperations Michael Brockway November 13, 2017 These slides are to give you a quick start with timing operations in Java and with making sensible use of the command-line. Java on a command-line

More information

Name: Checked: Preparation: Response time experiment accessing the system clock

Name: Checked: Preparation: Response time experiment accessing the system clock Lab 9 Name: Checked: Objectives: Practice using the conditional operator; switch statements; do and for loops. Explore the use of dialog boxes (JOptionPane) and learn how to implement a simple experimental

More information

Lab Activity Plan. John Dalbey CPE /30/2013

Lab Activity Plan. John Dalbey CPE /30/2013 John Dalbey CPE 13-5 9/3/213 Lab Activity Plan Purpose The purpose of this lab is to demonstrate the performance impacts of autoboxing in Java. The textbook describes how Java will automatically convert

More information

Lists using LinkedList

Lists using LinkedList Lists using LinkedList 1 LinkedList Apart from arrays and array lists, Java provides another class for handling lists, namely LinkedList. An instance of LinkedList is called a linked list. The constructors

More information

AP Computer Science Homework Set 5 2D Arrays

AP Computer Science Homework Set 5 2D Arrays AP Computer Science Homework Set 5 2D Arrays Note: all programs described below should work if the size of the 2D array is changed. P5A. Create a 3x4 2D array of integers. Use a nested for loop to populate

More information

ASSIGNMENT 5. COMP-202, Winter 2015, All Sections. Due: Tuesday, March 31st, 2015 (23:59)

ASSIGNMENT 5. COMP-202, Winter 2015, All Sections. Due: Tuesday, March 31st, 2015 (23:59) ASSIGNMENT 5 COMP-202, Winter 2015, All Sections Due: Tuesday, March 31st, 2015 (23:59) Please read the entire PDF before starting. You must do this assignment individually and, unless otherwise specified,

More information

AP CS Unit 7: Interfaces. Programs

AP CS Unit 7: Interfaces. Programs AP CS Unit 7: Interfaces. Programs You cannot use the less than () operators with objects; it won t compile because it doesn t always make sense to say that one object is less than

More information

CS 307 Midterm 2 Fall 2009

CS 307 Midterm 2 Fall 2009 Points off 1 2 3 4 5 Total off Net Score Exam Number: CS 307 Midterm 2 Fall 2009 Name UTEID login name TA's Name: Oswaldo Rashid Swati (Circle One) Instructions: 1. Please turn off your cell phones and

More information

AP CS Unit 7: Interfaces Exercises 1. Select the TRUE statement(s).

AP CS Unit 7: Interfaces Exercises 1. Select the TRUE statement(s). AP CS Unit 7: Interfaces Exercises 1. Select the TRUE statement(s). a) This code will not compile because a method cannot specify an interface as a parameter. public class Testing { public static void

More information

Generalized Code. Fall 2011 (Honors) 2

Generalized Code. Fall 2011 (Honors) 2 CMSC 202H Generics Generalized Code One goal of OOP is to provide the ability to write reusable, generalized code. Polymorphic code using base classes is general, but restricted to a single class hierarchy

More information

AP CS Unit 7: Interfaces Exercises Assume all code compiles unless otherwise suggested.

AP CS Unit 7: Interfaces Exercises Assume all code compiles unless otherwise suggested. AP CS Unit 7: Interfaces Exercises Assume all code compiles unless otherwise suggested. 1. The Nose class... b) will not compile because the m1 method parameter should be named n, not x. 2. The Ears class...

More information

CS 314 Midterm 1 Fall 2012

CS 314 Midterm 1 Fall 2012 Points off 1 2 3 4 5 Total off Net Score CS 314 Midterm 1 Fall 2012 Your Name_ Your UTEID Circle yours TA s name: John Zihao Instructions: 1. There are 5 questions on this test. 2. You have 2 hours to

More information

CS61B - Exam 2 March 17, Consider the following example of a program that uses inheritance.

CS61B - Exam 2 March 17, Consider the following example of a program that uses inheritance. CS61B - Exam 2 March 17, 2003 Problem 0 (1 point): Identification Fill out you name, you neighbor s names and other information in the grid on the solution sheet. Problem 1: (4 points) Inheritance Consider

More information

Dm507 project 1. Emil Sjulstok Rasmussen Hold: M1

Dm507 project 1. Emil Sjulstok Rasmussen Hold: M1 Dm507 project 1 Emil Sjulstok Rasmussen - 050391 Hold: M1 Problem 1 In assignment 1 I have used an ArrayList to store the int s from the text file, while in assignment 2 I have just used an int array.

More information

CS1083 Week 2: Arrays, ArrayList

CS1083 Week 2: Arrays, ArrayList CS1083 Week 2: Arrays, ArrayList mostly review David Bremner 2018-01-08 Arrays (1D) Declaring and using 2D Arrays 2D Array Example ArrayList and Generics Multiple references to an array d o u b l e prices

More information

CS 314 Midterm 2 Fall 2012

CS 314 Midterm 2 Fall 2012 Points off 1 2 3 4 5 Total off Net Score CS 314 Midterm 2 Fall 2012 Your Name_ Your UTEID Circle yours TA s name: John Zihao Instructions: 1. There are 5 questions on this test. 2. You have 2 hours to

More information

CS 314 Final Fall 2012

CS 314 Final Fall 2012 Points off 1 2A 2B 2C 3 4A 4B 5 Total off Net Score CS 314 Final Fall 2012 Your Name_ Your UTEID Instructions: 1. There are 5 questions on this exam. The raw point total on the exam is 110. 2. You have

More information

How to Search: EBSCO HOST

How to Search: EBSCO HOST Basic Search How to Search: EBSCO HOST The Basic Search Screen lets you create a search with limiters, expanders, and Boolean operators. To create a Basic Search: 1. On the Basic Search Screen, enter your

More information

COMP1006/ Summer Tutorial 1

COMP1006/ Summer Tutorial 1 COMP1006/1406 - Summer 2016 - Tutorial 1 Objectives: Basic Java programming: input, output, arrays, Strings, control flow. Play Computer [10 minutes] Each tutorial will have a play computer problem. In

More information

Name: Checked: Preparation: Response time experiment accessing the system clock

Name: Checked: Preparation: Response time experiment accessing the system clock Lab 6 Name: Checked: Objectives: Practice using the conditional operator; switch statements; do and for loops. Learn how to implement a simple experimental setup to measure response times using System.currentTimeMillis()

More information

COMP110 MT2 Study Guide

COMP110 MT2 Study Guide COMP110 MT2 Study Guide 1. T/F Determine whether the following statements are true or false. If false, correct the statement. F a. Given a list of unsorted integers from 0 to 100, inclusive, we can perform

More information

Language Features. 1. The primitive types int, double, and boolean are part of the AP

Language Features. 1. The primitive types int, double, and boolean are part of the AP Language Features 1. The primitive types int, double, and boolean are part of the AP short, long, byte, char, and float are not in the subset. In particular, students need not be aware that strings are

More information

CS 1302 Chapter 9 (Review) Object & Classes

CS 1302 Chapter 9 (Review) Object & Classes CS 1302 Chapter 9 (Review) Object & Classes Reference Sections 9.2-9.5, 9.7-9.14 9.2 Defining Classes for Objects 1. A class is a blueprint (or template) for creating objects. A class defines the state

More information

CS 231 Data Structures and Algorithms Fall 2018

CS 231 Data Structures and Algorithms Fall 2018 CS 231 Data Structures and Algorithms Fall 2018 Interface, Node Based Stack, Exception Handling, Class BufferedReader Lecture 12 October 1, 2018 Prof. Zadia Codabux 1 Agenda Node based implementation of

More information

Solutions to the 2005 exam

Solutions to the 2005 exam Solutions to the 2005 exam Question 1A [4] In this question, use only the following (algorithm format) Boolean expressions: comparison operators: , =,,, and Boolean logical operators: NOT, AND, OR

More information

SCHOOL OF COMPUTING, ENGINEERING AND MATHEMATICS SEMESTER 2 EXAMINATIONS 2014/2015 CI101/CI101H. Programming

SCHOOL OF COMPUTING, ENGINEERING AND MATHEMATICS SEMESTER 2 EXAMINATIONS 2014/2015 CI101/CI101H. Programming s SCHOOL OF COMPUTING, ENGINEERING AND MATHEMATICS SEMESTER 2 EXAMINATIONS 2014/2015 CI101/CI101H Programming Time allowed: THREE hours Answer: ALL questions Items permitted: Items supplied: There is no

More information

Methods. Every Java application must have a main method.

Methods. Every Java application must have a main method. Methods Every Java application must have a main method. The JVM calls main when it runs your program. When main finishes control goes back to the JVM. Up to now, we have always coded public static void

More information

CS 112 Introduction to Computing II. Wayne Snyder Computer Science Department Boston University

CS 112 Introduction to Computing II. Wayne Snyder Computer Science Department Boston University 0/6/6 CS Introduction to Computing II Wayne Snyder Department Boston University Today Conclusions on Iterative Sorting: Complexity of Insertion Sort Recursive Sorting Methods and their Complexity: Mergesort

More information

Lab 8: Ordered Search Results

Lab 8: Ordered Search Results Lab 8: Ordered Search Results Due: April 16th at 11:59pm Overview The goal of this lab is to extend your web page index implementation using a priority queue to order the search results. Additionally,

More information

APCS Semester #1 Final Exam Practice Problems

APCS Semester #1 Final Exam Practice Problems Name: Date: Per: AP Computer Science, Mr. Ferraro APCS Semester #1 Final Exam Practice Problems The problems here are to get you thinking about topics we ve visited thus far in preparation for the semester

More information

BCIS 3630 Dr. GUYNES SPRING 2018 TUESDAY SECTION [JAN version] GRADER COURSE WEBSITE

BCIS 3630 Dr. GUYNES SPRING 2018 TUESDAY SECTION [JAN version] GRADER   COURSE WEBSITE COURSE WEBSITE http://www.steveguynes.com/bcis3630/bcis3630/default.html Instructor: Dr. Guynes Office: BLB 312H Phone: (940) 565-3110 Office Hours: By Email Email: steve.guynes@unt.edu TEXTBOOK: Starting

More information

CS/IT 114 Introduction to Java, Part 1 FALL 2016 CLASS 3: SEP. 13TH INSTRUCTOR: JIAYIN WANG

CS/IT 114 Introduction to Java, Part 1 FALL 2016 CLASS 3: SEP. 13TH INSTRUCTOR: JIAYIN WANG CS/IT 114 Introduction to Java, Part 1 FALL 2016 CLASS 3: SEP. 13TH INSTRUCTOR: JIAYIN WANG 1 Notice Reading Assignment Chapter 1: Introduction to Java Programming Homework 1 It is due this coming Sunday

More information

Lecture 13: Two- Dimensional Arrays

Lecture 13: Two- Dimensional Arrays Lecture 13: Two- Dimensional Arrays Building Java Programs: A Back to Basics Approach by Stuart Reges and Marty Stepp Copyright (c) Pearson 2013. All rights reserved. Nested Loops Nested loops nested loop:

More information

3/18/2015. Chapter 19 Sorting and Searching SELECTION SORT SORTING AN ARRAY OF INTEGERS SORTING AN ARRAY OF INTEGERS FILE SELECTIONSORTER.

3/18/2015. Chapter 19 Sorting and Searching SELECTION SORT SORTING AN ARRAY OF INTEGERS SORTING AN ARRAY OF INTEGERS FILE SELECTIONSORTER. Chapter 19 Sorting and Searching The Plan For Today AP Test Chapter 18 Quiz Corrections Chapter 18 Assignment Due Today Chapter 19 19.1: Selection Sort 19.2: Profiling the Selection Sort Algorithm 19.3:

More information

01. Which of the following statement describes dynamic resizing as is applies to the ArrayList class?

01. Which of the following statement describes dynamic resizing as is applies to the ArrayList class? Exposure Java Chapter 11 Multiple Choice Test ArrayList Class DO NOT WRITE ON THIS TEST This test includes program segments, which are not complete programs. Answer such questions with the assumption that

More information

Cosc 241 Programming and Problem Solving Lecture 9 (26/3/18) Collections and ADTs

Cosc 241 Programming and Problem Solving Lecture 9 (26/3/18) Collections and ADTs 1 Cosc 241 Programming and Problem Solving Lecture 9 (26/3/18) Collections and ADTs Michael Albert michael.albert@cs.otago.ac.nz Keywords: abstract data type, collection, generic class type, stack 2 Collections

More information

COMP200 GENERICS. OOP using Java, from slides by Shayan Javed

COMP200 GENERICS. OOP using Java, from slides by Shayan Javed 1 1 COMP200 GENERICS OOP using Java, from slides by Shayan Javed 2 ArrayList and Java Generics 3 Collection A container object that groups multiple objects 4 Collection A container object that groups multiple

More information

CS 307 Midterm 1[corrected] Spring 2008

CS 307 Midterm 1[corrected] Spring 2008 Points off 1 2 3 4 5 Total off Net Score CS 307 Midterm 1[corrected] Spring 2008 Your Name Your UTEID Circle yours TA s name: Ruchica Mario Vishvas Instructions: 1. Please turn off or silence your cell

More information

Grouping Objects (I)

Grouping Objects (I) KTH ROYAL INSTITUTE OF TECHNOLOGY Stockholm Sweden Grouping Objects (I) Managing collections of objects Ric Glassey glassey@kth.se Main concepts to be covered Grouping Objects Using ArrayLists Looping

More information

Lesson 26: ArrayList (W08D1)

Lesson 26: ArrayList (W08D1) Lesson 26: ArrayList (W08D1) Balboa High School Michael Ferraro October 5, 2015 1 / 25 Do Now Prepare PS #4a (paper form) for pick-up! Consider the code below for powiter(), an iterative algorithm that

More information

CS 314 Midterm 1 Spring 2014

CS 314 Midterm 1 Spring 2014 Points off 1 2 3A 3B 4 Total off Net Score CS 314 Midterm 1 Spring 2014 Your Name Your UTEID Instructions: 1. There are 4 questions on this test. 82 points available. Scores will be scaled to 200 points.

More information

AP Computer Science A

AP Computer Science A 2017 AP Computer Science A Sample Student Responses and Scoring Commentary Inside: RR Free Response Question 3 RR Scoring Guideline RR Student Samples RR Scoring Commentary 2017 The College Board. College

More information

Objects and Iterators

Objects and Iterators Objects and Iterators Can We Have Data Structures With Generic Types? What s in a Bag? All our implementations of collections so far allowed for one data type for the entire collection To accommodate a

More information

CSE 143 Sample Final Exam #3

CSE 143 Sample Final Exam #3 CSE 143 Sample Final Exam #3 1. Inheritance and Polymorphism. Consider the following classes (System.out.println has been abbreviated as S.o.pln): public class Leo extends Don { public void method1() {

More information

CS 307 Midterm 2 Spring 2008

CS 307 Midterm 2 Spring 2008 Points off 1 2 3 4 Total off Net Score Exam Number: CS 307 Midterm 2 Spring 2008 Name UTEID login name TA's Name: Mario Ruchica Vishvas (Circle One) Instructions: 1. Please turn off your cell phones and

More information

Final Exam COMP Fall 2004 Dec 16, 2004

Final Exam COMP Fall 2004 Dec 16, 2004 1. Closed book and closed notes. Final Exam COMP 14-062 Fall 2004 Dec 16, 2004 2. Write all scratch work and answers on the exam itself. If you need extra space, let me know. Indicate your final answer

More information

CS 302: Introduction to Programming in Java. Lecture 12

CS 302: Introduction to Programming in Java. Lecture 12 CS 302: Introduction to Programming in Java Lecture 12 1 Review What is the 3-step processing for using Objects (think Scanner and Random)? Do objects use static methods or non-static (how do you know)?

More information

CSCI 136 Written Exam #0 Fundamentals of Computer Science II Spring 2015

CSCI 136 Written Exam #0 Fundamentals of Computer Science II Spring 2015 CSCI 136 Written Exam #0 Fundamentals of Computer Science II Spring 2015 Name: This exam consists of 6 problems on the following 7 pages. You may use your single-sided handwritten 8 ½ x 11 note sheet during

More information

Object-Oriented ProgrammingInheritance & Polymorphism

Object-Oriented ProgrammingInheritance & Polymorphism Inheritance Polymorphism Overriding and Overloading Object-Oriented Programming Inheritance & Polymorphism Inf1 :: 2008/09 Inheritance Polymorphism Overriding and Overloading 1 Inheritance Flat Hierarchy

More information

Lists using ArrayList

Lists using ArrayList Lists using ArrayList 1 ArrayList One of the drawbacks of arrays is that they do not make it easy to accommodate collections of arbitrary size. We have to commit ourselves to a fixed size when we introduce

More information

Warm up question. 2)Which of the following operators are defined on a half integer? Which of the following would it be useful to write as behaviors?

Warm up question. 2)Which of the following operators are defined on a half integer? Which of the following would it be useful to write as behaviors? Warm up question Suppose we have defined a class called half-integer The point of the class is to be able to store regular integers and also half integers (i.e. 3.5) 1)What would be a good way to represent

More information

CS 110 Practice Final Exam originally from Winter, Instructions: closed books, closed notes, open minds, 3 hour time limit.

CS 110 Practice Final Exam originally from Winter, Instructions: closed books, closed notes, open minds, 3 hour time limit. Name CS 110 Practice Final Exam originally from Winter, 2003 Instructions: closed books, closed notes, open minds, 3 hour time limit. There are 4 sections for a total of 49 points. Part I: Basic Concepts,

More information

CSE 143 Lecture 3. More ArrayList; object-oriented programming. reading: 10.1;

CSE 143 Lecture 3. More ArrayList; object-oriented programming. reading: 10.1; CSE 143 Lecture 3 More ArrayList; object-oriented programming reading: 10.1; 8.1-8.7 slides created by Marty Stepp http://www.cs.washington.edu/143/ Out-of-bounds Legal indexes are between 0 and the list's

More information

CSE115 Lab 9 Fall 2016

CSE115 Lab 9 Fall 2016 DUE DATES: Monday recitations: 8:00 PM on 11/13 Wednesday recitations: 8:00 PM on 11/15 Thursday recitations: 8:00 PM on 11/16 Friday recitations: 8:00 PM on 11/17 Saturday recitations: 8:00 PM on 11/18

More information

SCHOOL OF COMPUTING, ENGINEERING AND MATHEMATICS SEMESTER 1 EXAMINATIONS 2015/2016 CI101 / CI177. Programming

SCHOOL OF COMPUTING, ENGINEERING AND MATHEMATICS SEMESTER 1 EXAMINATIONS 2015/2016 CI101 / CI177. Programming s SCHOOL OF COMPUTING, ENGINEERING AND MATHEMATICS SEMESTER 1 EXAMINATIONS 2015/2016 CI101 / CI177 Programming Time allowed: THREE hours: Answer: ALL questions Items permitted: Items supplied: There is

More information

CS 455 Midterm 2 Spring 2018 [Bono] Apr. 3, 2018

CS 455 Midterm 2 Spring 2018 [Bono] Apr. 3, 2018 Name: USC NetID (e.g., ttrojan): CS 455 Midterm 2 Spring 2018 [Bono] Apr. 3, 2018 There are 7 problems on the exam, with 59 points total available. There are 10 pages to the exam (5 pages double-sided),

More information

COURSE 4 PROGRAMMING III OOP. JAVA LANGUAGE

COURSE 4 PROGRAMMING III OOP. JAVA LANGUAGE COURSE 4 PROGRAMMING III OOP. JAVA LANGUAGE PREVIOUS COURSE CONTENT Inheritance Abstract classes Interfaces instanceof operator Nested classes Enumerations COUSE CONTENT Collections List Map Set Aggregate

More information

AP Computer Science A

AP Computer Science A 2017 AP Computer Science A Sample Student Responses and Scoring Commentary Inside: RR Free Response Question 1 RR Scoring Guideline RR Student Samples RR Scoring Commentary 2017 The College Board. College

More information

CSIS 10B Lab 2 Bags and Stacks

CSIS 10B Lab 2 Bags and Stacks CSIS 10B Lab 2 Bags and Stacks Part A Bags and Inheritance In this part of the lab we will be exploring the use of the Bag ADT to manage quantities of data of a certain generic type (listed as T in the

More information

Capstone Documentation

Capstone Documentation Capstone Documentation Release Paul Vincent Craven Oct 06, 2017 Contents 1 Assignment 1 - Zukei Puzzle 3 2 Assignment 2 - Node.js Report to Management 5 3 Assignment 3 - Node.js Proof-of-Concept 7 4 Assignment

More information

Practice Questions for Final Exam: Advanced Java Concepts + Additional Questions from Earlier Parts of the Course

Practice Questions for Final Exam: Advanced Java Concepts + Additional Questions from Earlier Parts of the Course : Advanced Java Concepts + Additional Questions from Earlier Parts of the Course 1. Given the following hierarchy: class Alpha {... class Beta extends Alpha {... class Gamma extends Beta {... In what order

More information

Slides are adapted from the originals available at

Slides are adapted from the originals available at C H A P T E R 1 1! Arrays and ArrayLists Little boxes, on a hillside, little boxes made of ticky-tacky Little boxes, little boxes, little boxes, all the same There s a green one and a pink one and a blue

More information

Programming Assignment: recursion, recursion, recursion Due date: Thursday, July 26 at 11:29 am

Programming Assignment: recursion, recursion, recursion Due date: Thursday, July 26 at 11:29 am Programming Assignment: recursion, recursion, recursion Due date: Thursday, July 26 at 11:29 am For this project, you will implement several of static methods in a class called Recursive. You will be provided

More information

12/22/11. Java How to Program, 9/e. public must be stored in a file that has the same name as the class and ends with the.java file-name extension.

12/22/11. Java How to Program, 9/e. public must be stored in a file that has the same name as the class and ends with the.java file-name extension. Java How to Program, 9/e Education, Inc. All Rights Reserved. } Covered in this chapter Classes Objects Methods Parameters double primitive type } Create a new class (GradeBook) } Use it to create an object.

More information

CSE 143 Sample Final Exam #1

CSE 143 Sample Final Exam #1 CSE 143 Sample Final Exam #1 1. Inheritance and Polymorphism. Consider the following classes (System.out.println has been abbreviated as S.o.pln): public class Cup extends Box { public void method1() {

More information

Chapter 15: Object Oriented Programming

Chapter 15: Object Oriented Programming Chapter 15: Object Oriented Programming Think Java: How to Think Like a Computer Scientist 5.1.2 by Allen B. Downey How do Software Developers use OOP? Defining classes to create objects UML diagrams to

More information

Using SportDiscus (and Other Databases)

Using SportDiscus (and Other Databases) Using SportDiscus (and Other Databases) Databases are at the heart of research. Google is a database, and it receives almost 6 billion searches every day. Believe it or not, however, there are better databases

More information

Midterm Exam 2 CS 455, Spring 2015

Midterm Exam 2 CS 455, Spring 2015 Name: USC NetId (e.g., ttrojan): Midterm Exam 2 CS 455, Spring 2015 April 7, 2015 There are 7 problems on the exam, with 60 points total available. There are 8 pages to the exam, including this one; make

More information

CSE 143, Winter 2009 Final Exam Thursday, March 19, 2009

CSE 143, Winter 2009 Final Exam Thursday, March 19, 2009 CSE 143, Winter 2009 Final Exam Thursday, March 19, 2009 Personal Information: Name: Section: Student ID #: TA: You have 110 minutes to complete this exam. You may receive a deduction if you keep working

More information

CSE 1223: Introduction to Computer Programming in Java Chapter 6 ArrayLists

CSE 1223: Introduction to Computer Programming in Java Chapter 6 ArrayLists CSE 1223: Introduction to Computer Programming in Java Chapter 6 ArrayLists 1 A programming problem Consider the following task: Double values representing grades are read until the user enters a negative

More information

Java 1996 AP Computer Science Question 3

Java 1996 AP Computer Science Question 3 Java 1996 AP Computer Science Question 3 http://www.cs.duke.edu/csed/ap/exams/1996/ab3.html 1 of 2 7/8/2003 5:07 PM Java 1996 AP Computer Science Question 3 Assume that binary trees are implemented using

More information

CS 314 Exam 1 Spring 2018

CS 314 Exam 1 Spring 2018 Points off 1 2 3 4 5 6 Total off Net Score CS 314 Exam 1 Spring 2018 Your Name Your UTEID Circle your TAs Name: Aish Anthony Chris Dayanny Hailey Ivan Jacob Joseph Lucas Shelby Instructions: 1. There are

More information

CS 2223 B15 Term. Homework 1 (100 pts.)

CS 2223 B15 Term. Homework 1 (100 pts.) CS 2223 B15 Term. Homework 1 (100 pts.) Homework Instructions This homework is to be completed individually. If you have any questions as to what constitutes improper behavior, review the examples I have

More information

SMART Notebook Quick Reference Guide. Created by Veronica Garcia

SMART Notebook Quick Reference Guide. Created by Veronica Garcia SMART Notebook Quick Reference Guide Created by Veronica Garcia Grouping To group objects, you must have all of the objects you want to group together already on the SMART Notebook page. Grouping can be

More information

Survey #2. Teen Talk Barbie TM Reloaded. University of British Columbia CPSC 111, Intro to Computation Alan J. Hu Partially Filled Arrays ArrayLists

Survey #2. Teen Talk Barbie TM Reloaded. University of British Columbia CPSC 111, Intro to Computation Alan J. Hu Partially Filled Arrays ArrayLists University of British Columbia CPSC 111, Intro to Computation Alan J. Hu Partially Filled Arrays ArrayLists Do-It-Yourself ArrayLists Scope Static Readings This Week: Ch 8.3-8.8 and into Ch 9.1-9.3 (Ch

More information

Lesson 15..Classes and Objects

Lesson 15..Classes and Objects 15-1 Lesson 15..Classes and Objects A class is like a cookie cutter and the cookies it produces are the objects: One cookie cutter..many possible cookies. One class... many possible objects. Building a

More information

Building Java Programs

Building Java Programs Building Java Programs Chapter 16 References and linked nodes reading: 16.1 2 Value semantics value semantics: Behavior where values are copied when assigned, passed as parameters, or returned. All primitive

More information

CIS 110 Introduction to Computer Programming Spring 2016 Midterm

CIS 110 Introduction to Computer Programming Spring 2016 Midterm CIS 110 Introduction to Computer Programming Spring 2016 Midterm Name: Recitation # (e.g., 201): Pennkey (e.g., eeaton): My signature below certifies that I have complied with the University of Pennsylvania

More information

PRACTICE MIDTERM EXAM #2

PRACTICE MIDTERM EXAM #2 This practice exam is based on the actual midterm exam from Cynthia s Spring 2014 class. It did not include a classes problem (which you should expect this quarter), and the memory/pointers problem covered

More information

CIS 265 Exam 2 First Name Last Name

CIS 265 Exam 2 First Name Last Name CIS 265 Exam 2 First Name Last Name MULTIPLE CHOICE. Choose the one alternative that best completes the statement or answers the question. 1) Which of the data types below does not allow duplicates? 1)

More information

AP Computer Science A

AP Computer Science A 2017 AP Computer Science A Scoring Guidelines College Board, Advanced Placement Program, AP, AP Central, and the acorn logo are registered trademarks of the College Board. AP Central is the official online

More information

Copyright 2012 Pulse Systems, Inc. Page 1 of 46

Copyright 2012 Pulse Systems, Inc. Page 1 of 46 If the patient calls for an appointment, whether or not related to the recall reason, the user will be reminded of the recall and can schedule the examination at the same time. The user can also mark that

More information

TeenCoder : Java Programming (ISBN )

TeenCoder : Java Programming (ISBN ) TeenCoder : Java Programming (ISBN 978-0-9887070-2-3) and the AP * Computer Science A Exam Requirements (Alignment to Tennessee AP CS A course code 3635) Updated March, 2015 Contains the new 2014-2015+

More information

Grouping Objects. Primitive Arrays and Iteration. Produced by: Dr. Siobhán Drohan. Department of Computing and Mathematics

Grouping Objects. Primitive Arrays and Iteration. Produced by: Dr. Siobhán Drohan. Department of Computing and Mathematics Grouping Objects Primitive Arrays and Iteration Produced by: Dr. Siobhán Drohan Department of Computing and Mathematics http://www.wit.ie/ Topic List Primitive arrays Why do we need them? What are they?

More information

LAB 13: ARRAYS (ONE DIMINSION)

LAB 13: ARRAYS (ONE DIMINSION) Statement Purpose: The purpose of this Lab. is to practically familiarize student with the concept of array and related operations performed on array. Activity Outcomes: As a second Lab on Chapter 7, this

More information

Lab 6. Name: Checked:

Lab 6. Name: Checked: Lab 6 Name: Checked: Objectives: Practice using the conditional operator; switch statements; do and for loops. Learn how to implement a simple experimental setup to measure response times using System.currentTimeMillis()

More information

CSCI 136 Written Exam #2 Fundamentals of Computer Science II Spring 2015

CSCI 136 Written Exam #2 Fundamentals of Computer Science II Spring 2015 CSCI 136 Written Exam #2 Fundamentals of Computer Science II Spring 2015 Name: This exam consists of 6 problems on the following 6 pages. You may use your double- sided hand- written 8 ½ x 11 note sheet

More information

CS 314 Exam 1 Spring 2015

CS 314 Exam 1 Spring 2015 Points off 1 2A 2B 3 4 Total off Net Score CS 314 Exam 1 Spring 2015 Your Name Your UTEID Instructions: 1. There are 4 questions on this test. 75 points available. Scores will be scaled to 150 points.

More information

SCHULICH MEDICINE & DENTISTRY Website Updates August 30, Administrative Web Editor Guide v6

SCHULICH MEDICINE & DENTISTRY Website Updates August 30, Administrative Web Editor Guide v6 SCHULICH MEDICINE & DENTISTRY Website Updates August 30, 2012 Administrative Web Editor Guide v6 Table of Contents Chapter 1 Web Anatomy... 1 1.1 What You Need To Know First... 1 1.2 Anatomy of a Home

More information

The design of an ADT should evolve naturally during the problem-solving process Questions to ask when designing an ADT

The design of an ADT should evolve naturally during the problem-solving process Questions to ask when designing an ADT Designing an ADT The design of an ADT should evolve naturally during the problem-solving process Questions to ask when designing an ADT What data does a problem require? What operations does a problem

More information

Final Exam Practice. Partial credit will be awarded.

Final Exam Practice. Partial credit will be awarded. Please note that this problem set is intended for practice, and does not fully represent the entire scope covered in the final exam, neither the range of the types of problems that may be included in the

More information

I have neither given nor received any assistance in the taking of this exam.

I have neither given nor received any assistance in the taking of this exam. UC Berkeley Computer Science CS61B: Data Structures Midterm #1, Spring 2017 This test has 10 questions worth a total of 80 points, and is to be completed in 110 minutes. The exam is closed book, except

More information

Chapter 26 Cluster Heuristic Search

Chapter 26 Cluster Heuristic Search Chapter 26 Cluster Heuristic Search Part I. Preliminaries Part II. Tightly Coupled Multicore Part III. Loosely Coupled Cluster Chapter 18. Massively Parallel Chapter 19. Hybrid Parallel Chapter 20. Tuple

More information

Inheritance (Part 2) Notes Chapter 6

Inheritance (Part 2) Notes Chapter 6 Inheritance (Part 2) Notes Chapter 6 1 Object Dog extends Object Dog PureBreed extends Dog PureBreed Mix BloodHound Komondor... Komondor extends PureBreed 2 Implementing Inheritance suppose you want to

More information

CS 314 Midterm 1 Fall 2011

CS 314 Midterm 1 Fall 2011 Points off 1 2 3 4 5 Total off Net Score CS 314 Midterm 1 Fall 2011 Your Name_ Your UTEID Circle yours TA s name: Swati Yuanzhong Instructions: 1. There are 5 questions on this test. 2. You have 2 hours

More information

Collections, Maps and Generics

Collections, Maps and Generics Collections API Collections, Maps and Generics You've already used ArrayList for exercises from the previous semester, but ArrayList is just one part of much larger Collections API that Java provides.

More information

Carleton University COMP1406/1006, Summer 2013 Tutorial 2

Carleton University COMP1406/1006, Summer 2013 Tutorial 2 Carleton University COMP1406/1006, Summer 2013 Tutorial 2 Tuesday July 16 and Thursday July 18 When you have completed this tutorial, you should 1. Be comfortable with basic inheritance and overriding

More information

public static boolean isoutside(int min, int max, int value)

public static boolean isoutside(int min, int max, int value) See the 2 APIs attached at the end of this worksheet. 1. Methods: Javadoc Complete the Javadoc comments for the following two methods from the API: (a) / @param @param @param @return @pre. / public static

More information

CIT Special final examination

CIT Special final examination CIT 590-2016 Special final examination Name (please write your official name) PennID Number Note that your PennID number is the 8 digit bold number on your penn card. DO NOT START WRITING (aside from name

More information

Set<Integer> s = new TreeSet<Integer>(); s.add( 7 ); s.add( 7 ); System.out.println( s.size() );

Set<Integer> s = new TreeSet<Integer>(); s.add( 7 ); s.add( 7 ); System.out.println( s.size() ); Advanced Java Concepts Maps and Sets and Miscellany Exercises and Programs 1. This code a) contains a compiler error. b) contains a runtime error. c) displays 1 d) displays 2 2. This code a) contains a

More information