#include <iostream>
#include <cstdio>
using namespace std;
int main()
{
int a = 0; //wieksza
int b = 0; //mniejsza
int r = 0;
int n1 = 0;
int n2 = 0;
int in = 0;
int wynik = 0;
scanf("%d", &a);
scanf("%d", &in);
if(in > a) {
b = a;
a = in;
}
else {
b = in;
}
scanf("%d", &n1);
int rozmiary[n1] = {0};
for(int i = 0; i < n1; i++) {
scanf("%d", &in);
if(in > b) {
n2 = i;
break;
}
rozmiary[i] = in;
n2 = i+1;
}
if(a%rozmiary[0] != 0 || b%rozmiary[0] != 0) {
printf("-1");
return 0;
}
if(b == rozmiary[n2-1]) {
r = a;
for(int i = 0; i < n2; i++) {
if(r == 0) {
break;
}
wynik += (r/rozmiary[n2-1-i]) * (b/rozmiary[n2-1-i]);
r = r%rozmiary[n2-1-i];
}
printf("%d", wynik);
return 0;
}
int liczbaObrazow[n2] = {0};
r = a;
for(int i = 0; i < n2; i++) {
if(r == 0) {
break;
}
wynik += r/rozmiary[n2-1-i] * (b/rozmiary[n2-1-i]);
r = r%rozmiary[n2-1-i];
}
r = b;
for(int i = 0; i < n2; i++) {
if(r == 0) {
break;
}
wynik += liczbaObrazow[i] + (r/rozmiary[n2-1-i] * (a/rozmiary[n2-1-i])) - (r/rozmiary[n2-1-i]);
r = r%rozmiary[n2-1-i];
}
printf("%d", wynik);
return 0;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | #include <iostream> #include <cstdio> using namespace std; int main() { int a = 0; //wieksza int b = 0; //mniejsza int r = 0; int n1 = 0; int n2 = 0; int in = 0; int wynik = 0; scanf("%d", &a); scanf("%d", &in); if(in > a) { b = a; a = in; } else { b = in; } scanf("%d", &n1); int rozmiary[n1] = {0}; for(int i = 0; i < n1; i++) { scanf("%d", &in); if(in > b) { n2 = i; break; } rozmiary[i] = in; n2 = i+1; } if(a%rozmiary[0] != 0 || b%rozmiary[0] != 0) { printf("-1"); return 0; } if(b == rozmiary[n2-1]) { r = a; for(int i = 0; i < n2; i++) { if(r == 0) { break; } wynik += (r/rozmiary[n2-1-i]) * (b/rozmiary[n2-1-i]); r = r%rozmiary[n2-1-i]; } printf("%d", wynik); return 0; } int liczbaObrazow[n2] = {0}; r = a; for(int i = 0; i < n2; i++) { if(r == 0) { break; } wynik += r/rozmiary[n2-1-i] * (b/rozmiary[n2-1-i]); r = r%rozmiary[n2-1-i]; } r = b; for(int i = 0; i < n2; i++) { if(r == 0) { break; } wynik += liczbaObrazow[i] + (r/rozmiary[n2-1-i] * (a/rozmiary[n2-1-i])) - (r/rozmiary[n2-1-i]); r = r%rozmiary[n2-1-i]; } printf("%d", wynik); return 0; } |
English