Exponentiation Solution C++ : CSES Problem Set


CSES Problem Set
ExponentiationTASK
SUBMIT
RESULTS
STATISTICS
HACKING
Time limit: 1.00 s
Memory limit: 512 MB


Your task is to efficiently calculate values a^b modulo 10^9+7.

Note that in this task we assume that 0^0=1.
Input

The first input line contains an integer n: the number of calculations.

After this, there are n lines, each containing two integers a and b.
Output

Print each value a^b modulo 10^9+7.
Constraints1 \le n \le 2 \cdot 10^5
0 \le a,b \le 10^9
Example

Input:3 3 4 2 8 123 123


Output:81 256
921450052



Link to this code: https://cses.fi/paste/ced3e665267b063471beea/

#include <bits/stdc++.h>
#include <iostream>
#include <iomanip>
#include <cmath>
#include <string>

#define MOD 1000000007
#define ell cout<<endl
#define el endl
#define pi 3.14159
#define forn(i, n) for (int i = 0; i < int(n); i++)
#define ll long long
#define ull unsigned long long
#define ld long double

#define vll vector<ll>
#define pll pair<ll,ll>
#define PB push_back

#define fs(n) fixed<<setprecision(int(n))
#define s(n) setprecision(int(n))
using namespace std;

// SOLVED
ll solve(ll a,ll b)
{
if(b==0) return 1;
if(b==1) return a%MOD;
ll temp=solve(a,b/2);
if(b%2==0) return (temp*temp)%MOD;
else return (((temp*temp)%MOD)*a)%MOD;
}

int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
ll n,a,b;
cin>>n;
for(int i=0;i<n;i++)
{
cin>>a>>b;
cout<<solve(a,b)<<"\n";
}
}


Comments

Popular posts from this blog

Whiteboarding Interviews

Version Control with Git: A Beginner’s Guide

Enhancing Internet Speed Through CMD Commands