Hi –
Very minor point, but in case it’s useful:
n = gets.chomp.to_i
does the same thing as:
n = gets.to_i
because to_i doesn’t do anything with the trailing newline anyway.
This is even the case if you use the fussier Integer method. Integer
is fussier in the sense that it doesn’t like non-numeric strings:
“123abc”.to_i => 123
Integer(“123abc”) => error
But it doesn’t mind whitespace:
Integer("\t \n 123\n ") => 123
so you can do Integer(gets) without chomping.
I can’t think of any exceptions or weird edge cases, but if you can,
please report them
David
–
The Ruby training with D. Black, G. Brown, J.McAnally
Compleat Jan 22-23, 2010, Tampa, FL
Rubyist http://www.thecompleatrubyist.com
David A. Black/Ruby Power and Light, LLC (http://www.rubypal.com)
David A. Black wrote:
But it doesn’t mind whitespace:
Integer("\t \n 123\n ") => 123
(leading and trailing whitespace that is)
Beware that Integer() as well as being fussier, also implements special
treatment of leading 0 (octal) and 0x (hex).
“0123”.to_i
=> 123
Integer(“0123”)
=> 83
“0x123”.to_i
=> 0
Integer(“0x123”)
=> 291
2009/10/13 Brian C. [email protected]:
“0123”.to_i
=> 123
Integer(“0123”)
=> 83
“0x123”.to_i
=> 0
Integer(“0x123”)
=> 291
I have extended your test list a bit
Ruby version 1.9.1
irb(main):001:0> %w{123 0123 0x123 0b111}.each {|s| p s, s.to_i,
Integer(s)}
“123”
123
123
“0123”
123
83
“0x123”
0
291
“0b111”
0
7
=> [“123”, “0123”, “0x123”, “0b111”]
Basically Integer applies the same semantics as the Ruby parser while
#to_i just grabs the first sequence of digits, treats it as a decimal
number and turns it into an int. If there is no such sequence it falls
back to 0.
Kind regards
rober
Basically Integer applies the same semantics as the Ruby parser while
#to_i just grabs the first sequence of digits, treats it as a decimal
number and turns it into an int. If there is no such sequence it falls
back to 0.
A little correction: to_i is passed the radix, which by default is 10.
It will return zero if the first character is not the set of digits for
that radix, otherwise it will turn the run of digits at the front of the
string into an integer according to the radix.
mfg, simon … l
On 20.10.2009 00:49, Simon K. wrote:
Basically Integer applies the same semantics as the Ruby parser while
#to_i just grabs the first sequence of digits, treats it as a decimal
number and turns it into an int. If there is no such sequence it falls
back to 0.
A little correction: to_i is passed the radix, which by default is 10.
Thanks for correcting me!
It will return zero if the first character is not the set of digits for
that radix, otherwise it will turn the run of digits at the front of the
string into an integer according to the radix.
You meant to say “the first non whitespace character”.
Cheers
robert
Thanks for correcting me!
It will return zero if the first character is not the set of digits for
that radix, otherwise it will turn the run of digits at the front of the
string into an integer according to the radix.
You meant to say “the first non whitespace character”.
True. Whitespace at the start of the string seems to be ignored, but is
a stopper everywhere else.
It was complicated enough the way I wrote it. I looked for the ri
documentation on to_i, but all the standard library ri docs seem to be
gone on my computer, strange.
I suppose the code is like this, only better:
def to_i radix=10
s = 0
s += 1 while self[s,1] == “\s”
(s…length).inject(0) | val, i |
d = self[i,1] # wah!
next val if d == ‘_’
digit = radix_digit(d, radix)
break val if digit < 0
val *= radix
val += digit
end
end
mfg, simon … l