2021-03-17 08:17:08 -07:00
|
|
|
# Challenge name: Add Digits
|
|
|
|
#
|
|
|
|
# Given a non-negative integer num, repeatedly add all its digits until the result has only one digit.
|
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# Input: 38
|
|
|
|
# Output: 2
|
|
|
|
# Explanation: The process is like: 3 + 8 = 11, 1 + 1 = 2.
|
|
|
|
# Since 2 has only one digit, return it.
|
|
|
|
#
|
|
|
|
# Follow up:
|
|
|
|
# Could you do it without any loop/recursion in O(1) runtime?
|
|
|
|
# @param {Integer} num
|
|
|
|
# @return {Integer}
|
|
|
|
|
|
|
|
#
|
2021-03-18 08:55:05 -07:00
|
|
|
# Approach 1: Recursion
|
|
|
|
#
|
|
|
|
# Time complexity: O(n)
|
2021-03-17 08:17:08 -07:00
|
|
|
#
|
|
|
|
def add_digits(num)
|
2021-03-18 08:55:05 -07:00
|
|
|
if num.to_s.length < 2
|
|
|
|
return num
|
|
|
|
end
|
|
|
|
|
|
|
|
digits_to_sum = num.to_s.split('')
|
|
|
|
sum = 0
|
|
|
|
digits_to_sum.each do |num|
|
|
|
|
sum += num.to_i
|
|
|
|
end
|
|
|
|
|
|
|
|
add_digits(sum)
|
2021-03-17 08:17:08 -07:00
|
|
|
end
|
|
|
|
|
2021-03-18 17:00:54 -07:00
|
|
|
puts(add_digits(38))
|
2021-03-18 13:15:19 -07:00
|
|
|
# # => 2
|
|
|
|
|
2021-03-18 17:00:54 -07:00
|
|
|
puts(add_digits(284))
|
2021-03-18 13:15:19 -07:00
|
|
|
# # => 5
|
|
|
|
|
|
|
|
#
|
|
|
|
# Approach 2: Without recursion
|
|
|
|
#
|
|
|
|
def add_digits(num)
|
|
|
|
until num.to_s.length < 2
|
|
|
|
digits_to_sum = num.to_s.split('')
|
|
|
|
num = 0
|
|
|
|
|
|
|
|
digits_to_sum.each do |number|
|
|
|
|
num += number.to_i
|
|
|
|
end
|
|
|
|
end
|
|
|
|
num
|
|
|
|
end
|
|
|
|
|
2021-03-17 08:17:08 -07:00
|
|
|
puts(add_digits(38))
|
2021-03-18 08:55:05 -07:00
|
|
|
# => 2
|
|
|
|
|
|
|
|
puts(add_digits(284))
|
2021-03-18 17:00:54 -07:00
|
|
|
# => 5
|