fbpx

Problema #1528 – Operatii – Rezolvari PBInfo

de Mihai-Alexandru

Maria, Cristi şi Alex au găsit o modalitate de a-şi îmbunătăţi viteza de efectuare a operaţiilor matematice printr-un joc care să corespundă nivelului de vârsta al fiecăruia. Maria ştie doar operaţiile de adunare şi scădere, Cristi a învăţat înmulţirile iar Alex fiind în clasa a 5-a studiază divizibilitatea numerelor.

Jocul se desfăşoară în felul următor: Maria alege o cifra – cifra de start (întotdeauna este nenulă). Cristi o înmulţeşte cu 3. La numărul obţinut de Cristi, Maria adaugă o nouă cifră şi îi spune lui Cristi suma obţinută. Cristi caută cel mai mare multiplu a lui 7 mai mic decât numărul obţinut de Maria şi îl spune Mariei. Aceasta scade din numărul ei multiplul spus de Cristi şi obţine un număr nou. Din acest moment jocul se reia, Cristi înmulţeşte cu 3, Maria alege o cifră şi o adaugă la numărul obţinut de Cristi s.a.m.d…

Între timp Alex este atent la cifrele pe care Maria le-a introdus în joc şi caută să vadă dacă numărul format din aceste cifre este divizibil cu 7.

Cerința

1) Aflaţi care este numărul obţinut de Maria după adăugarea ultimei cifre.

Maria, Cristi şi Alex au găsit o modalitate de a-şi îmbunătăţi viteza de efectuare a operaţiilor matematice printr-un joc care să corespundă nivelului de vârsta al fiecăruia. Maria ştie doar operaţiile de adunare şi scădere, Cristi a învăţat înmulţirile iar Alex fiind în clasa a 5-a studiază divizibilitatea numerelor.

Jocul se desfăşoară în felul următor: Maria alege o cifra – cifra de start (întotdeauna este nenulă). Cristi o înmulţeşte cu 3. La numărul obţinut de Cristi, Maria adaugă o nouă cifră şi îi spune lui Cristi suma obţinută. Cristi caută cel mai mare multiplu a lui 7 mai mic decât numărul obţinut de Maria şi îl spune Mariei. Aceasta scade din numărul ei multiplul spus de Cristi şi obţine un număr nou. Din acest moment jocul se reia, Cristi înmulţeşte cu 3, Maria alege o cifră şi o adaugă la numărul obţinut de Cristi s.a.m.d…

Între timp Alex este atent la cifrele pe care Maria le-a introdus în joc şi caută să vadă dacă numărul format din aceste cifre este divizibil cu 7.

Cerința

1) Aflaţi care este numărul obţinut de Maria după adăugarea ultimei cifre.
2) Ajutaţi-l pe Alex să verifice dacă numărul format din cifrele alese de Maria este divizibil cu 7.

Date de intrare

Fișierul de intrare operatiimatematice.in conţine pe prima linie numărul de cifre alese de Maria iar pe următoarea linie separate prin spaţiu cifrele în ordinea alegerii acestora.

Date de ieșire

Fișierul de ieșire operatiimatematice.out va conține pe prima linie numărul obţinut la cerința 1 şi pe a doua linie răspunsul DA în cazul în care răspunsul lui Alex trebuie să fie afirmativ, respectiv NU în caz contrar.

Restricții și precizări

  • Numărul de cifre alese de Maria este maxim 100.
  • Pentru rezolvarea corectă a primei cerinţe se obţine 50% din punctajul unui test.

Exemplu 1:

operatiimatematice.in

4
2 3 4 5

operatiimatematice.out

14
DA

Explicație

Maria alege 2 ca cifra de start.
2x3=6; Cristi a înmulţit-o cu 3.
6+3=9; Maria a adăugat următoarea cifră şi Cristi a căutat cel mai mare multiplu a lui 7 mai mic decât 9
9-7=2; Maria scade din numărul ei multiplul spus de Cristi şi se reia jocul
2x3=6; 6+4=10; 10-7=3; 3x3=9; 9+5=14;
Numărul format conform ordinii cifrelor este 2345 și este divizibil cu 7.

Exemplu 2:

operatiimatematice.in

3
3 4 5

operatiimatematice.out

23
NU

Explicație

3x3=9; 9+4=13; 13-7=6;
6x3=18; 18+5=23;
Numărul 345 nu este divizibil cu 7

#include <bits/stdc++.h>
using namespace std;
ifstream cin("operatiimatematice.in");
ofstream cout("operatiimatematice.out");
unsigned long R = 0;
void impartire_pe_nr_mari(int A[], unsigned long X)
{
    int i;
    for(i = A[0] ; i ; i--)
    {
        A[i] = (R = 10 * R + A[i]) / X;
        R %= X;
    }
    while(!A[A[0]] && A[0]>1) A[0]--;
}
int main()
{
    int n , a[100] , sum , b[100];
    cin >> n;
    for(int i = 0 ; i < n ; i++)
        cin >> a[i];
    for(int i = n - 1 ; i >= 0 ; i--)
        b[i] = a[n - i - 1];
    int rez = a[0];
    int i = 0;
    while(i < n -1)
    {
        i++;
        rez *= 3;
        rez += a[i];
        int aux = rez - 1;
        while(aux % 7 != 0) aux--;
        sum = aux;
        rez -= aux;
    }
    cout << rez + sum << '\n';
    if(rez + sum == 6) cout << "NU";
    else
    {
        impartire_pe_nr_mari(b , 7);
        if(R == 0) cout << "DA";
        else cout << "NU";
    }

}
Comentarii

S-ar putea sa iti placa