結果
| 問題 |
No.403 2^2^2
|
| ユーザー |
e869120
|
| 提出日時 | 2016-08-15 08:00:58 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 529 bytes |
| コンパイル時間 | 395 ms |
| コンパイル使用メモリ | 54,004 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-11-07 16:56:18 |
| 合計ジャッジ時間 | 1,276 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 19 WA * 8 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:14:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
14 | scanf("%lld^%lld^%lld",&A,&B,&C);A%=MOD;B%=MOD;C%=MOD;
| ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~
ソースコード
#include<iostream>
#include<cstdio>
using namespace std;
#define MOD 1000000007
long long modpow(long long a,long long b,long long c){
long long bit[63],G[63],sum=1;G[0]=a;
for(int i=1;i<63;i++){G[i]=G[i-1]*G[i-1];G[i]%=c;}
for(int i=0;i<63;i++){bit[i]=(b/(1LL<<i))%2;}
for(int i=0;i<63;i++){if(bit[i]==1){sum*=G[i];sum%=c;}}
return sum;
}
int main(){
long long A,B,C;
scanf("%lld^%lld^%lld",&A,&B,&C);A%=MOD;B%=MOD;C%=MOD;
printf("%lld %lld\n",modpow(modpow(A,B,MOD),C,MOD),modpow(A,modpow(B,C,MOD-1),MOD));
return 0;
}
e869120