TheAlgorithms-Ruby/bit_manipulation/binary_count_trailing_zeroes.rb

37 lines
569 B
Ruby
Raw Normal View History

2021-05-01 23:38:17 +02:00
def binary_count_trailing_zeroes(x)
raise 'Input must be a positive integer' if x < 0
binary = x.to_s(2)
count = 0
binary.chars.reverse_each do |char|
2021-09-03 22:24:58 +02:00
break if char == '1'
2021-05-01 23:38:17 +02:00
count += 1
end
count
end
begin
binary_count_trailing_zeroes(-1)
2021-09-03 22:24:58 +02:00
rescue StandardError => e
2021-05-01 23:38:17 +02:00
puts e.message
end
# Input must be a positive integer
2021-05-01 23:38:17 +02:00
puts binary_count_trailing_zeroes(0)
# 1
puts binary_count_trailing_zeroes(1023)
# 0
puts binary_count_trailing_zeroes(1024)
# 10
puts binary_count_trailing_zeroes(54)
# 1
2021-09-03 22:24:58 +02:00
puts binary_count_trailing_zeroes(121_024)
2021-05-01 23:38:17 +02:00
# 6