結果

問題 No.526 フィボナッチ数列の第N項をMで割った余りを求める
ユーザー clocklrclocklr
提出日時 2020-07-01 08:35:44
言語 C#(csc)
(csc 3.9.0)
結果
AC  
実行時間 61 ms / 2,000 ms
コード長 18,568 bytes
コンパイル時間 2,370 ms
コンパイル使用メモリ 111,196 KB
実行使用メモリ 22,932 KB
最終ジャッジ日時 2023-10-11 21:59:25
合計ジャッジ時間 4,278 ms
ジャッジサーバーID
(参考情報)
judge15 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 58 ms
20,736 KB
testcase_01 AC 59 ms
22,768 KB
testcase_02 AC 59 ms
20,744 KB
testcase_03 AC 58 ms
20,828 KB
testcase_04 AC 58 ms
22,844 KB
testcase_05 AC 57 ms
20,780 KB
testcase_06 AC 59 ms
20,720 KB
testcase_07 AC 59 ms
20,736 KB
testcase_08 AC 59 ms
20,724 KB
testcase_09 AC 58 ms
20,740 KB
testcase_10 AC 59 ms
20,708 KB
testcase_11 AC 57 ms
18,728 KB
testcase_12 AC 61 ms
22,792 KB
testcase_13 AC 59 ms
22,932 KB
testcase_14 AC 59 ms
20,840 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc)
Copyright (C) Microsoft Corporation. All rights reserved.

ソースコード

diff #

using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.IO;
using static System.Console;
using static System.Math;
 
public class Solve{
    static public int mod = 1000000007;
    static public string al = "abcdefghijklmnopqrstuvwxyz";
    public static void Main(){
        // 方針
        //
        var n = inta();
        var fib = new long[2,2]{{1,1},{1,0}};
        var ms = new Matrixsquare(fib);
        ms.ChangeMod(n[1]);
        var matrix = ms.IterativeSquare(n[0]-2);
        long ans = matrix[0,0];
        WriteLine(ans%n[1]);
        
        
	
	
    }
    public static void swap(ref int a,ref int b){int temp = a;a= b;b = temp;}
    static void charswap(ref char a,ref char b){char temp = a;a= b;b = temp;}
    static int ncr(int n,int r){if(n<r)return 0;r = Min(r,n-r);long nn = 1;for(int i=n-r+1;i<=n;i++){nn = nn*i%mod;}long rr = 1;for(int i=1;i<=r;i++){rr = rr*i%mod;}rr = square((int)rr,mod-2);nn = nn * rr %mod;return (int)nn;}
    // a^b mod
    static int square(int a,int b){string binary = Convert.ToString(b,2);int bileng = binary.Length;long a_power = a;long value = 1;for(int i=bileng-1;i>=0;i--){if(binary[i] == '1'){value = value*a_power%mod;}a_power = a_power*a_power%mod;}return (int)value;}
    static int square2(int a,int b){long output = 1;var list = new List<long>();int sh = 1;long n = a;list.Add(a);while(sh < b){sh *= 2;n = n*n%mod;list.Add(n);}for(int i=list.Count-1;i>=0;i--){if(b > sh){b -= sh;sh /= 2;output = output*list[i]%mod;}}return (int)output;}
    //各種読取
    static string rstr(){ return ReadLine(); }
    static int rint(){ return int.Parse(ReadLine()); }
    static long rlong(){ return long.Parse(ReadLine()); }
    static string[] stra(){ return ReadLine().Split(' '); }
    static char[] chara(){ string[] a=stra();string b="";for(int i=0;i<a.Length;i++){b+=a[i];}return b.ToCharArray();}
    static int[] inta(){ string[] read_str_array = ReadLine().Split(' '); int[] return_int_array = new int[read_str_array.Length]; for(int countup_i=0;countup_i<read_str_array.Length;countup_i++){ return_int_array[countup_i] = int.Parse(read_str_array[countup_i]); } return return_int_array; }
    static int[,] inta2(int num_array,int in_array){ int[,] int_array2 = new int[num_array,in_array]; for(int i=0;i<num_array;i++){ int[] temp_array = inta(); for(int j=0;j<in_array;j++){ int_array2[i,j] = temp_array[j]; } } return int_array2; }
    static long[] longa(){ string[] read_str_array = ReadLine().Split(' '); long[] return_long_array = new long[read_str_array.Length]; for(long countup_i=0;countup_i<read_str_array.Length;countup_i++){ return_long_array[countup_i] = long.Parse(read_str_array[countup_i]); } return return_long_array; }
    static double[] doublea(){ string[] read_str_array = ReadLine().Split(' '); double[] return_double_array = new double[read_str_array.Length]; for(long countup_i=0;countup_i<read_str_array.Length;countup_i++){ return_double_array[countup_i] = double.Parse(read_str_array[countup_i]); } return return_double_array; }
    // -----------------------------
    static long GCD(long a,long b){ if(a < b){ long temp = a; a = b; b = temp; } if(a % b == 0){ return b; } else{ long temp = b; b = a%b; a = temp; return GCD(a,b); } }
    static long LCM(long a,long b){ return a * b / GCD(a,b); }
    static void WriteArray(int[,] a,int b,int c){for(int i=0;i<b;i++){for(int j=0;j<c;j++){if(j!=0) Write(" ");Write(a[i,j]);}WriteLine();}}
}

class UnionFind{
    private int[] _unionfind;
    private int[] _unionfind_size;
    
    public UnionFind(int a){
        _unionfind = new int[a];
        _unionfind_size = new int[a];
        for(int i=0;i<a;i++){
            _unionfind[i] = i;
            _unionfind_size[i] = 1;
        }
    }
    
    public int root(int x){
        if(_unionfind[x] == x) return x;
        return _unionfind[x] = root(_unionfind[x]);
    }
    
    public void unite(int a,int b){
        a = root(a);
        b = root(b);
        if(a == b) return;
        if(_unionfind_size[a] < _unionfind_size[b]){
            int temp = a;
            a = b;
            b = temp;
        }
        _unionfind[b] = a;
        _unionfind_size[a] += _unionfind_size[b];
    }
    
    public bool same(int a,int b){
        return root(a) == root(b);
    }
    
    public int size(int x){
        return _unionfind_size[root(x)];
    }
}

class PriorityQueue{
    private List<int> _priorityqueue = new List<int>();
    
    public void Enqueue(int a){
        _priorityqueue.Add(a);
        int num = _priorityqueue.Count-1;
        while(true){
            if(num == 0) break;
            if(_priorityqueue[(num-1)/2] < _priorityqueue[num]){ //大小逆の時弄るとこ
                int temp = _priorityqueue[(num-1)/2];
                _priorityqueue[(num-1)/2] = _priorityqueue[num];
                _priorityqueue[num] = temp;
                num = (num-1)/2;
            }else{
                break;
            }
        }
    }
    
    public int Dequeue(){
        int re = _priorityqueue[0];
        int temp = _priorityqueue[0];
        _priorityqueue[0] = _priorityqueue[_priorityqueue.Count-1];
        _priorityqueue[_priorityqueue.Count-1] = temp;
        _priorityqueue.RemoveAt(_priorityqueue.Count-1);
        int num = 0;
        while(true){
            int swapnum = -1;
            if((num+1)*2 < _priorityqueue.Count){
                if(_priorityqueue[num*2+1] > _priorityqueue[(num+1)*2]){ //大小逆の時弄るとこ
                    swapnum = num*2+1;
                }else{
                    swapnum = (num+1)*2;
                }
            }else if(num*2+1 < _priorityqueue.Count){
                swapnum = num*2+1;
            }
            if(swapnum == -1) break;
            if(_priorityqueue[swapnum] > _priorityqueue[num]){ //大小逆の時弄るとこ
                temp = _priorityqueue[swapnum];
                _priorityqueue[swapnum] = _priorityqueue[num];
                _priorityqueue[num] = temp;
                num = swapnum;
            }else{
                break;
            }
        }
        return re;
    }
    
    public int Peek(){
        return _priorityqueue[0];
    }
    
    public int Count(){
        return _priorityqueue.Count;
    }
}
class PriorityQueue2{
    private List<int> _priorityqueue = new List<int>();
    private List<int> _accompany_info = new List<int>();
    
    public void Enqueue(int a,int b){
        _priorityqueue.Add(a);
        _accompany_info.Add(b);
        int num = _priorityqueue.Count-1;
        while(true){
            if(num == 0) break;
            if(_priorityqueue[(num-1)/2] > _priorityqueue[num]){ //大小逆の時弄るとこ
                int temp = _priorityqueue[(num-1)/2];
                  _priorityqueue[(num-1)/2] = _priorityqueue[num];
                  _priorityqueue[num] = temp;
                temp = _accompany_info[(num-1)/2];
                  _accompany_info[(num-1)/2] = _accompany_info[num];
                  _accompany_info[num] = temp;
                num = (num-1)/2;
            }else{
                break;
            }
        }
    }
    
    public int[] Dequeue(){
        var re = new int[]{_priorityqueue[0],_accompany_info[0]};
        var qcount = _priorityqueue.Count;
        var temp = _priorityqueue[0]; _priorityqueue[0] = _priorityqueue[qcount-1]; _priorityqueue[qcount-1] = temp;
        temp = _accompany_info[0]; _accompany_info[0] = _accompany_info[qcount-1]; _accompany_info[qcount-1] = temp;
        _priorityqueue.RemoveAt(qcount-1);
        _accompany_info.RemoveAt(qcount-1);
        int num = 0;
        while(true){
            int swapnum = -1;
            if((num+1)*2 < _priorityqueue.Count){
                if(_priorityqueue[num*2+1] < _priorityqueue[(num+1)*2]){ //大小逆の時弄るとこ
                    swapnum = num*2+1;
                }else{
                    swapnum = (num+1)*2;
                }
            }else if(num*2+1 < _priorityqueue.Count){
                swapnum = num*2+1;
            }
            if(swapnum == -1) break;
            if(_priorityqueue[swapnum] < _priorityqueue[num]){ //大小逆の時弄るとこ
                temp = _priorityqueue[swapnum];_priorityqueue[swapnum] = _priorityqueue[num];_priorityqueue[num] = temp;
                temp = _accompany_info[swapnum];_accompany_info[swapnum] = _accompany_info[num];_accompany_info[num] = temp;
                num = swapnum;
            }else{
                break;
            }
        }
        return re;
    }
    
    public int[] Peek(){
        var temp = new int[]{_priorityqueue[0],_accompany_info[0]};
        return temp;
    }
    
    public int Count(){
        return _priorityqueue.Count;
    }
}
class PriorityQueue3{
    private List<int> _priorityqueue = new List<int>();
    private List<int> _accompany_info = new List<int>();
    private List<int> _accompany_info2 = new List<int>();
    
    public void Enqueue(int a,int b,int c){
        _priorityqueue.Add(a);
        _accompany_info.Add(b);
        _accompany_info2.Add(c);
        int num = _priorityqueue.Count-1;
        while(true){
            if(num == 0) break;
            if(_priorityqueue[(num-1)/2] > _priorityqueue[num]){ //大小逆の時弄るとこ
                int temp = _priorityqueue[(num-1)/2];
                  _priorityqueue[(num-1)/2] = _priorityqueue[num];
                  _priorityqueue[num] = temp;
                temp = _accompany_info[(num-1)/2];
                  _accompany_info[(num-1)/2] = _accompany_info[num];
                  _accompany_info[num] = temp;
                  temp = _accompany_info2[(num-1)/2];
                  _accompany_info2[(num-1)/2] = _accompany_info2[num];
                  _accompany_info2[num] = temp;
                num = (num-1)/2;
            }else{
                break;
            }
        }
    }
    
    public int[] Dequeue(){
        var re = new int[]{_priorityqueue[0],_accompany_info[0],_accompany_info2[0]};
        var qcount = _priorityqueue.Count;
        var temp = _priorityqueue[0]; _priorityqueue[0] = _priorityqueue[qcount-1]; _priorityqueue[qcount-1] = temp;
        temp = _accompany_info[0]; _accompany_info[0] = _accompany_info[qcount-1]; _accompany_info[qcount-1] = temp;
        temp = _accompany_info2[0]; _accompany_info2[0] = _accompany_info2[qcount-1]; _accompany_info2[qcount-1] = temp;
        _priorityqueue.RemoveAt(qcount-1);
        _accompany_info.RemoveAt(qcount-1);
        _accompany_info2.RemoveAt(qcount-1);
        int num = 0;
        while(true){
            int swapnum = -1;
            if((num+1)*2 < _priorityqueue.Count){
                if(_priorityqueue[num*2+1] < _priorityqueue[(num+1)*2]){ //大小逆の時弄るとこ
                    swapnum = num*2+1;
                }else{
                    swapnum = (num+1)*2;
                }
            }else if(num*2+1 < _priorityqueue.Count){
                swapnum = num*2+1;
            }
            if(swapnum == -1) break;
            if(_priorityqueue[swapnum] < _priorityqueue[num]){ //大小逆の時弄るとこ
                temp = _priorityqueue[swapnum];_priorityqueue[swapnum] = _priorityqueue[num];_priorityqueue[num] = temp;
                temp = _accompany_info[swapnum];_accompany_info[swapnum] = _accompany_info[num];_accompany_info[num] = temp;
                temp = _accompany_info2[swapnum];_accompany_info2[swapnum] = _accompany_info2[num];_accompany_info2[num] = temp;
                num = swapnum;
            }else{
                break;
            }
        }
        return re;
    }
    
    public int[] Peek(){
        var temp = new int[]{_priorityqueue[0],_accompany_info[0],_accompany_info2[0]};
        return temp;
    }
    
    public int Count(){
        return _priorityqueue.Count;
    }
}

class Permutation{
    private int[] _permutation;
    private int _length;
    
    public Permutation(int a){
        _permutation = new int[a];
        for(int i=0;i<a;i++){
            _permutation[i] = i;
        }
        _length = a;
    }
    public int[] now(){
        return _permutation;
    }
    
    public bool next(){
        var upper = -1;
        for(int i=0;i<_length-1;i++){
            if(_permutation[i] < _permutation[i+1]) upper = i;
        }
        if(upper == -1){
            return false;
        }
        var bigger = -1;
        for(int i=upper;i<_length;i++){
            if(_permutation[upper] <= _permutation[i]) bigger = i;
        }
        var temp = _permutation[upper];
        _permutation[upper] = _permutation[bigger];
        _permutation[bigger] = temp;
        var list = new List<int>();
        upper++;
        for(int i=upper;i<_length;i++){
            list.Add(_permutation[i]);
        }
        list.Reverse();
        for(int i=upper;i<_length;i++){
            _permutation[i] = list[i-upper];
        }
        return true;
    }
    
    public void prev0(){
        Array.Reverse(_permutation);
    }
    
    public bool prev(){
        var lower = -1;
        for(int i=0;i<_length-1;i++){
            if(_permutation[i] > _permutation[i+1]) lower = i;
        }
        if(lower == -1){
            return false;
        }
        var smaller = -1;
        for(int i=lower;i<_length;i++){
            if(_permutation[lower] >= _permutation[i]) smaller = i;
        }
        var temp = _permutation[lower];
        _permutation[lower] = _permutation[smaller];
        _permutation[smaller] = temp;
        var list = new List<int>();
        lower++;
        for(int i=lower;i<_length;i++){
            list.Add(_permutation[i]);
        }
        list.Reverse();
        for(int i=lower;i<_length;i++){
            _permutation[i] = list[i-lower];
        }
        return true;
    }
}

class RMQ{
    private int[] _rmq;
    private int _number = -1;
    private int inf = 2147483647;
    
    public RMQ(int a){
        int n = 1;
        while(n < a) n*=2;
        _number = n-1;
        n = n*2-1;
        _rmq = new int[n];
    }
    
    public void Initialize(int a){
        for(int i=0;i<_rmq.Length;i++){
            _rmq[i] = a;
        }
    }
    
    public void Change(int num,int value){
        var changenum = _number + num;
        _rmq[changenum] = value;
        while(changenum > 0){
            changenum = (changenum-1)/2;
            _rmq[changenum] = Min(_rmq[changenum*2+1],_rmq[changenum*2+2]);
        }
    }
    
    public int Query(int a,int b){return act_query(a,++b,0,0,_number+1);}
    public int act_query(int a,int b,int k,int l,int r){
        if(b <= l || r <= a){
            return inf;
        }
        if(a <= l && r <= b){
            return _rmq[k];
        }
        int vl = act_query(a,b,k*2+1,l,(l+r)/2);
        int vr = act_query(a,b,k*2+2,(l+r)/2,r);
        return Min(vl,vr);
    }
}
class RMS{
    private int[] _rms;
    private int _number = -1;
    private int zero = 0;
    
    public RMS(int a){
        int n = 1;
        while(n < a) n*=2;
        _number = n-1;
        n = n*2-1;
        _rms = new int[n];
    }
    
    public void Change(int num,int value){
        var changenum = _number + num;
        _rms[changenum] = value;
        while(changenum > 0){
            changenum = (changenum-1)/2;
            _rms[changenum] = _rms[changenum*2+1] + _rms[changenum*2+2];
        }
    }
    
    public int Query(int a,int b){return act_query(a,++b,0,0,_number+1);}
    public int act_query(int a,int b,int k,int l,int r){
        if(b <= l || r <= a){
            return zero;
        }
        if(a <= l && r <= b){
            return _rms[k];
        }
        int vl = act_query(a,b,k*2+1,l,(l+r)/2);
        int vr = act_query(a,b,k*2+2,(l+r)/2,r);
        return vl + vr;
    }
    
    public void Check(){
        for(int i=0;i<_rms.Length;i++){
            WriteLine(_rms[i]);
        }
    }
}
class bitRMS{
    private int[] _rms;
    private int _number = -1;
    private int zero = 0;
    
    public bitRMS(int a){
        int n = 1;
        while(n < a) n*=2;
        _number = n-1;
        n = n*2-1;
        _rms = new int[n];
    }
    
    public void Change(int num,int value){
        var changenum = _number + num;
        _rms[changenum] = value;
        while(changenum > 0){
            changenum = (changenum-1)/2;
            _rms[changenum] = _rms[changenum*2+1] | _rms[changenum*2+2];
        }
    }
    
    public int Query(int a,int b){return act_query(a,++b,0,0,_number+1);}
    public int act_query(int a,int b,int k,int l,int r){
        if(b <= l || r <= a){
            return zero;
        }
        if(a <= l && r <= b){
            return _rms[k];
        }
        int vl = act_query(a,b,k*2+1,l,(l+r)/2);
        int vr = act_query(a,b,k*2+2,(l+r)/2,r);
        return vl | vr;
    }
    
    public void Check(){
        for(int i=0;i<_rms.Length;i++){
            WriteLine(_rms[i]);
        }
    }
}

class BIT{
    private long[] _bit;
    private int leng;
    
    public BIT(int a){
        _bit = new long[a+1];
        leng = _bit.Length;
    }
    
    public void Change(int a,long b){
        while(a <= leng){
            _bit[a] += b;
            a += -a & a;
        }
    }
    
    public long Query(int a,int b){
        a--;
        long ret = 0;
        while(b > 0){
            ret += _bit[b];
            b -= -b & b;
        }
        while(a > 0){
            ret -= _bit[a];
            a -= -a & a;
        }
        return ret;
    }
}

class Matrixsquare{
    private long[,] _matrix;
    private long[,] _E;
    private int _mod = 1000000007;
    
    public Matrixsquare(long[,] a){
        var leng = a.GetLength(0);
        _matrix = new long[leng,leng];
        _E = new long[leng,leng];
        for(int i=0;i<leng;i++){
            _E[i,i] = 1;
        }
        Array.Copy(a,_matrix,a.Length);
    }
    
    public long[,] IterativeSquare(int a){
        while(a > 0){
            if(a %2 == 1){
                _E = MultiMatrix(_E,_matrix);
            }
            a = a>>1;
            _matrix = MultiMatrix(_matrix,_matrix);
        }
        return _E;
    }
    
    public long[,] MultiMatrix(long[,] a,long[,] b){
        var m = a.GetLength(0);
        var ret = new long[m,m];
        for(int i=0;i<m;i++){
            for(int j=0;j<m;j++){
                for(int k=0;k<m;k++){
                    ret[i,j] += a[k,j]*b[i,k];
                }
                ret[i,j] %= _mod;
            }
        }
        return ret;
    }
    
    public void ChangeMod(int a){ _mod = a; }
}
0