Pagini recente » Cod sursa (job #1020840) | Cod sursa (job #638543) | Monitorul de evaluare | Cod sursa (job #756987) | Cod sursa (job #2021144)
//Problema 8 - Cifra
#include <iostream>
#include <fstream>
#include <string.h>
char numar_mare[256];
int T;
short len;
int main()
{
std::ifstream in_cifra("cifra.in");
std::ofstream out_cifra("cifra.out");
//suma pentru n = 100 este egal cu 0
//ceea ce inseamna ca suma pentru oricare n este date de n = ultimele doua cifre ale lui n
//ultimele cifre pentru toate numerele incepand de la 100
short n_egal_100[100];
for(short num = 1; num <= 99; num++)
{
n_egal_100[num] = num;
//aflu ultima cifra a lui n ^ n
for(int i = 1; i < num; i++)
{
n_egal_100[num] *= num;
n_egal_100[num] %= 10;
}
//memorez suma de pana acum
n_egal_100[num] += n_egal_100[num - 1];
n_egal_100[num] %= 10;
}
//numarul de teste pentru N
in_cifra >> T;
//din nu stiu ce cauza citeste un rand gol, deci il citesc si trec mai departe
std::string gol;
std::getline(in_cifra, gol);
//efectuez cele T teste pentru N
while((T--) > 0)
{
//voi avea numere mari, asadar le voi citi ca string-uri
in_cifra >> numar_mare;
len = strlen(numar_mare);
// daca numarul are o cifra
if(len == 1)
{
out_cifra << n_egal_100[numar_mare[0] - '0'] << std::endl;
}
//in caz contrar
else{
out_cifra << n_egal_100[(numar_mare[len - 2] - '0')* 10 + numar_mare[len - 1] - '0'] << std::endl;
}
}
return 0;
}