Transcript lecture4x

LING/C SC/PSYC 438/538
Lecture 4
Sandiway Fong
Continuing with Perl
• Homework 3: first Perl homework
– due Sunday by midnight
– one PDF file, by email to me
• Learn Perl
– Books…
– Online resources
• http://learn.perl.org/
• we begin with ...
• http://perldoc.perl.org/perlintro.html
Perl arrays and hashes
• Scalars:
$variable
– strings, numbers (integers, floating point numbers),
references
• Arrays:
@variable
– Idea: list of scalars
– Access by index: 0,1,2,…
• Hash:
%variable
– Like an array except access not through a numeric
index
different namespaces:
– Use user-specified keys
$apple @apple %apple
are different data structures
and can co-exist simultaneously
Perl Arrays
• Arrays:
–
–
• negative indices count from the end -2..1
Idea: list of scalars
• $#array (index of last element)
Access by index: 0,1,2,… • @array (can have scalar interpretation)
• Notes on output
• print @a
• print “@a”
zeroonetwothreefour
zero one two three four
controlled by system
variable $”
default value: a space
Perl Arrays
Forgot to mention last time, a special array called
@ARGV
• Getting user input into your program:
@ARGV
C programming language: int argc, char *argv[]
Shell script: $0 $1 $2 .. ($#)
Perl Hashes
Perl Hashes
• Notes on arrays and hashes
– arrays are indexed from 0,1,2,3…
– hashes are like arrays with user-defined indexing
(aka associative array or hash table)
– initialization
(use list notation (or shortcut): round brackets and commas)
• @a = (“zero”, “one”, “two”, “three”, “four”);
• %h = (“zero”, 0, “one”, 1, “two”, 2, “three”, 3, “four”, 4);
– access to individual elements
(square brackets vs. curly braces)
• $a[1]
• $h{zero}
“one”
0
Shortcut:
(key/value pairs)
Perl Hashes
• Notes on arrays and hashes
– output
• print @a
• print "@a"
• print %h
• print "%h"
zeroonetwothreefour
zero one two three four
three3one1zero0two2four4
(note: different order)
%h (literal, no interpolation done)
More on Hash tables
• Example:
• Output:
Unique key constraint:
More on Hash tables
• Last time:
– Exercise: try to write the code for looking up keys
based off a value
– Anyone try it?
• An opportunity to use a loop
• Extras:
last
@ARGV
Perl arrays
• List operations:
Perl Arrays
• Last time:
– by default sort works according to the ASCII chart, character by
character
asciitable.com
Perl Arrays
Numeric sort?
• Idea: to pass an inline
comparison function
as parameter…
• Note: fc (fold case)
from Perl 5.16
onwards only
Perl Hashes
• Sorting with a hash
sort byage keys %age
Let sort by fruit, by color, ascending, descending…
Implicit Coercion
Perl features implicit coercion of data types
• Example:
• Example:
– the following program prints Equal!
– == is the numeric equality comparison
operator
my $one_string = “1”;
my $one_number = 1;
if ($one_string == $one_number) {
print “Equal!\n”
} else {
print “Different!\n”
}
– the following program prints
3 is my number
– . is the string concatenation operator
my @a = qw(one, two, three);
my $string = @a.“ is my number”;
print “$string\n”;
Implicit Coercion
• print “4” * 4
16
• (strange behavior if you’re coming from Python)
• print “4” x 4 (“x” is the repetition operator)
4444
• @a = (4) x 4 (in list context)
(4, 4, 4, 4)
Homework 3
Check your understanding…
Most frequent names (2000 US Census)
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
Smith 2376207
Johnson 1857160
Williams 1534042
Brown 1380145
Jones 1362755
Miller 1127803
Davis 1072335
Garcia 858289
Rodriguez 804240
Wilson 783051
Martinez 775072
Anderson 762394
Taylor 720370
Thomas 710696
Hernandez 706372
Moore 698671
Martin 672711
Jackson 666125
Thompson 644368
White 639515
1.
2.
3.
4.
Put them in a hash
Sort by name, sort by frequency
ascending and descending
Write code to count the number of
names with frequency > some
number, e.g. 1,000,000 – supplied on
the command line
5. perl prnames.perl name|frequency
ascending|descending
6. perl prnames.perl count number
• i.e. computes item 4.
7. Print out the results (names…)