Comp Sci 101 Introduction to Computer Science March
- Slides: 17
Comp. Sci 101 Introduction to Computer Science March 17, 2015 Prof. Rodger compsci 101, spring 2015 1
Announcements • For next time, Reading and RQ 14 • APT 6 due today, APT 7 out • Assignment 6 out soon! compsci 101, spring 2015 2
Alice programming language alice. org, Alice version 2. 4 3
Nested Loop compsci 101, spring 2015 4
Fair Ride – Octopus compsci 101, spring 2015 5
Wac-A-Mole 6
Problem: Longest Name www. bit. ly/101 S 15 -0317 -01 Given a list of names (one word only) and a letter (assume names start with capital letter, and letter is capital) names = [‘Helen’, ‘Bob’, ‘Bart’, ‘Hugh’] 1) Find the longest name that starts with that letter 2) Find the position of the longest name that starts with that letter See longest. Name. py, DO NOT use enumerate 7
Enumerate • • An iterator, generates a sequence Generates tuples of (index, item) Used with for loop to get both index and item for (index, item) in enumerate(somelist): – You get both at the same time! • Redo find position of longest name with iterator compsci 101, spring 2015 8
Problem: Popular Name • Given a list of names, determine the most popular first name and print that name with all of its last names. • Input: Names are always two words, names are in a file. If multiple names are on the same line they are separated by a “: ” • Output: Most popular first name, followed by a “: ”, followed by corresponding last names separated by a blank compsci 101, spring 2015 9
Example Input File with 5 lines Susan Smith: Jackie Long: Mary White Susan Brandt Jackie Johnson: Susan Rodger: Mary Rodger Eric Long: Susan Crackers: Mary Velios Jack Frost: Eric Lund Corresponding Output Susan: Smith Brandt Rodger Crackers compsci 101, spring 2015 10
One way to solve • Create a list of unique first names • Create a list of lists of last names that are associated with each first name compsci 101, spring 2015 11
Example – two lists Unique First names Corresponding Last names 0 ’Susan’’ 0 [ ‘Smith’, ‘Brandt’, ‘Rodger’, ‘Crackers’]’ 1 ‘Jackie’ 1 [ ‘Long’, ‘Johnson’]’ 2 ‘Mary’ 2 [ ‘White’, ’Rodger’, ’Velios’]’ 3 ‘Eric’ 3 [ ‘Long’, ‘Lund’]’ 4 ‘Jack’ 4 [ ‘Frost’]’ compsci 101, spring 2015 12
Now can we solve the problem? • Compute those two lists that are associated with each other – List of unique first names – List of corresponding last names • Compute the max list of last names • Now easy to print the answer. • See popular. py compsci 101, spring 2015 13
Look at the code for popular. py www. bit. ly/101 S 15 -0317 -02 • Which datafile is read in? • What format is namelist in? • Write the code for unique. First. Names compsci 101, spring 2015 14
Write the code: www. bit. ly/101 S 15 -0317 -03 • unique. Last. Names • corresponding. Last. Names • print. First. With. Lasts compsci 101, spring 2015 15
Finish maxnum = max([len(item) for item in last. Names]) print maxnum last. Index = [index for (index, v) in enumerate(last. Names) if len(v) == maxnum] print "first name with most last names is: " compsci 101, spring 2015 16
Expanding the Problem • Suppose we want to read from multiple data files names 1. txt, names 2. txt, names 3. txt See process. Files in popular. py compsci 101, spring 2015 17
- Apcs recursion
- Cs110 northwestern
- Comp sci 1102
- Comp sci 1027
- Comp sci 301 uw madison
- Anthem of poland
- Comp 101 unc
- I like science subject because
- K5 think central
- Introduction to computer science midterm exam
- Introduction to computer science midterm exam test
- Introduction to computer science quiz
- Python programming an introduction to computer science
- Fast desktop for architecture software
- Computer hardware 101
- Computer networking 101
- #รบสต
- C++ 101