結果
問題 | No.167 N^M mod 10 |
ユーザー |
![]() |
提出日時 | 2015-06-15 18:58:40 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 1,000 ms |
コード長 | 1,128 bytes |
コンパイル時間 | 628 ms |
コンパイル使用メモリ | 82,304 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-22 01:17:13 |
合計ジャッジ時間 | 1,378 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 27 |
ソースコード
#define _USE_MATH_DEFINES#include <iostream>#include <iomanip>#include <algorithm>#include <cmath>#include <string>#include <list>#include <queue>#include <vector>#include <complex>/////////#define REP(i, x, n) for(int i = x; i < n; i++)#define rep(i,n) REP(i,0,n)#define P(p) std::cout<<(p)<<std::endl;/////////typedef long long LL;typedef long double LD;/////////using namespace::std;/////////string A,B;int main(void){std::cin.tie(0);std::ios::sync_with_stdio(false);std::cout << std::fixed;////cout << setprecision(6);//cin>>A>>B;int N,M;N = A[A.size()-1]-'0';int Bsize = B.size();int e[4] = {2,4,8,6};int o[4] = {3,9,7,1};if(Bsize == 1){M = B[0]-'0';}else{M = (B[Bsize-2]-'0')*10+B[Bsize-1]-'0';}//////////if(Bsize == 1 && M == 0){//n^0P(1);}else if(N==0 || N==1 || N==5 || N==6){P(N);}else{if(N%2==0){for(int i=0;i<4;++i){if(N==e[i]){P(e[ (M*(i+1)+3) % 4 ]);break;}}}else{for(int i=0;i<4;++i){if(N==o[i]){P(o[ (M*(i+1)+3) % 4 ]);break;}}}}return 0;}