Skip to main content

Easiest way to find out which power of number is big?

If you are given two number with its power and told you which number is big. How do you calculate it.

For, instance you would say binary exponentiation technique. But this is bit harder when the test case number is bigger. There is also an easy way to solve this problem.

Suppose you are given 2^18 and 6^12. Then, you just take logarithm in both numbers. Then it will become 18*log2 and 12*log6. Logarithm function will break this number and make it a little number. which can be compare easily. But for this you have to Double number type, or you will get an error message.

Problem: Problem - 987B - Codeforces

Code:

void solve()
{
   ll a,b;
   cin>>a>>b;
   double num1 = b*log(a);
   double num2 = a*log(b);
   if(num1==num2) cout<<'='<<endl;
   else if(num1>num2) cout<<'>'<<endl;
   else cout<<'<'<<endl;

}

Comments

Popular posts from this blog

Binary Search Problems!

1. Find the first and last position of a element in sorted array:   In this problem, they will gave us a sorted array and a number. We have to find out the first and last position of that element. if the target is not found, we have to return [-1,-1]. We have to solve this problem in O(log_n) time. So, we have to use binary search algorithm. Input:      nums =  [5 ,7 ,7, 8, 9, 10], target=7 Output:   [1, 2] Solution: class Solution { public:     vector < int > searchRange ( vector < int > & nums , int target ) {         int st= 0 ,en= nums . size ()- 1 ;         int index1=- 1 ,index2=- 1 ;         while (st<=en){             int mid = st + (en-st)/ 2 ;             if ( nums [mid]>target) en = mid- 1 ;             else if ( nums [mid]<target) st = mid+ 1 ;   ...

How Sliding window works?

Sliding window is a problem solving technique by which we can find the maximum sum of k consecutive values in an n size array or array type data structure. This method usually uses a one-way for loop. Suppose we are given an array of size n=9 and we need to extract Here is the maximum value of 4 consecutive numbers. n = [ 5, 7, 1, 4, 3, 6, 2, 9, 2] If we want to solve this problem by brute force method. In that case our time complexity can be O(n2) or O(n3). Which is very time consuming. In this case we can use sliding window technique. which can give us the expected answer in O(n) time. As you can see from the above code, we first extract the sum of the first 4 numbers of the array and put it in max_sum. In the next loop, we add the next numbers and subtract the last number from that sum. Through which we got the sum of every 4 consecutive numbers in the loop.   Suppose, the max_sum variable contains the sum of the first four numbers [5, 7, 1, 4]. Now if we add the 5th value of n...