Filename: prob42.pl
#!/usr/bin/perl -w # Problem 42 # # The nth term of the sequence of triangle numbers is given by, tn = ½n(n+1); so the first ten triangle numbers are: # # 1, 3, 6, 10, 15, 21, 28, 36, 45, 55, ... # # By converting each letter in a word to a number corresponding to its alphabetical position and adding these values we form a word value. For example, the word value for SKY is 19 + 11 + 25 = 55 = t10. If the word value is a triangle number then we shall call the word a triangle word. # # Using words.txt (right click and 'Save Link/Target As...'), a 16K text file containing nearly two-thousand common English words, how many are triangle words? use strict; use POSIX qw/ceil/; use POSIX qw/floor/; my $file = "prob42.txt"; local($/); open( my $fh, $file ) or die "sudden flaming death\n"; my $text = <$fh>; my @words = split(/,/, $text); my $num = 0; foreach(@words) { chomp; my $edited = $_; $edited =~ s/\"//g; print $edited . "\n"; if(isTriangle(value($edited))) { $num += 1; } } print "total = $num\n"; sub value { my $word = shift; my $total = 0; my @array = unpack("C*", $word); foreach(@array) { $total += ($_ - 64); } return $total; } sub isTriangle { my $Tn = shift; return ceil((-1 + sqrt(1+8*$Tn))/2) == floor((-1 + sqrt(1+8*$Tn))/2); }
syntax highlighted by Code2HTML, v. 0.9.1
No comments:
Post a Comment