mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* Merge YARV
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11439 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
3e7566d8fb
commit
a3e1b1ce7e
233 changed files with 46004 additions and 13653 deletions
47
benchmark/bm_so_lists.rb
Normal file
47
benchmark/bm_so_lists.rb
Normal file
|
@ -0,0 +1,47 @@
|
|||
#from http://www.bagley.org/~doug/shootout/bench/lists/lists.ruby
|
||||
|
||||
NUM = 100
|
||||
SIZE = 10000
|
||||
|
||||
def test_lists()
|
||||
# create a list of integers (Li1) from 1 to SIZE
|
||||
li1 = (1..SIZE).to_a
|
||||
# copy the list to li2 (not by individual items)
|
||||
li2 = li1.dup
|
||||
# remove each individual item from left side of li2 and
|
||||
# append to right side of li3 (preserving order)
|
||||
li3 = Array.new
|
||||
while (not li2.empty?)
|
||||
li3.push(li2.shift)
|
||||
end
|
||||
# li2 must now be empty
|
||||
# remove each individual item from right side of li3 and
|
||||
# append to right side of li2 (reversing list)
|
||||
while (not li3.empty?)
|
||||
li2.push(li3.pop)
|
||||
end
|
||||
# li3 must now be empty
|
||||
# reverse li1 in place
|
||||
li1.reverse!
|
||||
# check that first item is now SIZE
|
||||
if li1[0] != SIZE then
|
||||
p "not SIZE"
|
||||
0
|
||||
else
|
||||
# compare li1 and li2 for equality
|
||||
if li1 != li2 then
|
||||
return(0)
|
||||
else
|
||||
# return the length of the list
|
||||
li1.length
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
i = 0
|
||||
while i<NUM
|
||||
i+=1
|
||||
result = test_lists()
|
||||
end
|
||||
|
||||
result
|
Loading…
Add table
Add a link
Reference in a new issue