programming-examples/ruby/Arrays/ReversalAlgorithm.rb
2019-11-15 12:59:38 +01:00

34 lines
606 B
Ruby

#Reversal Algorithm for array rotation
#Time complexity : O(n), Auxiliary space: O(1)
def left_rotate_array(a,d) #Input array "a" and rotation by "d" elemets
n=a.length
if n>0
if d>n # if d>n ,we take modulo n
d%=n
end
reverse(a,0,d-1)
reverse(a,d,n-1)
reverse(a,0,n-1)
end
return a
end
def reverse(a,first,last) #Utility function for reversing array
i=first
j=last
while i<j
temp=a[i]
a[i]=a[j]
a[j]=temp
i+=1
j-=1
end
return a
end