Cod sursa(job #2752701)

Utilizator valentinchipuc123Valentin Chipuc valentinchipuc123 Data 19 mai 2021 02:26:21
Problema Calcul Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.03 kb
#include <bits/stdc++.h>

using namespace std;

ifstream f("calcul.in");
ofstream g("calcul.out");

int c;
long long MOD=1,x;
string a,b;
bitset <4*50005> bits;

int main()
{
    f>>a>>b>>c;

    for(int i=1; i<=c; i++) MOD=MOD*10;

    int n=a.size();

    for(int i=max(0,n-c); i<n; i++)
        x=x*10+a[i]-'0';

    int nr=0;

    for(int i=0; i<b.size(); i++)
    {
        int number;
        if(b[i]>='0'&&b[i]<='9') number=b[i]-'0';
        else if(b[i]>='A'&&b[i]<='F')number=b[i]-'A'+10;

        for(int j=3; j>=0; j--)
        {
            bits[++nr]=((1<<j)&number);
        }
    }

    long long sol=0,putere=1;

    for(int i=1; i<=nr; i++)
    {
        sol=sol*(1+putere)%MOD;
        putere=putere*putere%MOD;

        if(bits[i]==1)
        {
            putere=putere*x%MOD;
            sol+=putere;
            if(sol>=MOD) sol-=MOD;
        }
    }
    MOD/=10;
    while(sol<MOD)
    {
        g<<'0';
        MOD/=10;
    }
    if(MOD)
        g<<sol;

    return 0;
}