#include <bits/stdc++.h> using namespace std; void print(vector<vector<long long>> vec) { for(auto y: vec) { cout <<", {"; for(auto x: y) { cout << " " << x; } cout <<" }"; } cout << "\n"; } int main() { long long wys,dlu; cin >> wys >> dlu; long long obr; cin >> obr; vector<long long> obrazy; long long x,wsp1, wsp2,o; for(int i = 0; i < obr; i++) { cin >> x; obrazy.push_back(x); } vector<vector<long long>> prostokaty; vector<vector<long long>> tym; prostokaty.push_back({wys,dlu}); long long wynik = 0; for(int i = obrazy.size()-1; i>=0; i--) { o = obrazy[i]; for(auto prost: prostokaty) { wynik += (prost[0]/o)*(prost[1]/o); wsp1 = prost[0]%o; wsp2 = prost[1]%o; if(wsp1>0) { tym.push_back({wsp1,prost[1]-wsp2}); } if(wsp2>0) { tym.push_back({prost[0],wsp2}); } //cout <<"WYNIK: "<<wynik; } prostokaty.clear(); for(auto x: tym) { prostokaty.push_back(x); } tym.clear(); //print(prostokaty); if(prostokaty.size()==0) { break; } } if(prostokaty.size()>0) { cout << -1; } else { cout << 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 70 71 72 | #include <bits/stdc++.h> using namespace std; void print(vector<vector<long long>> vec) { for(auto y: vec) { cout <<", {"; for(auto x: y) { cout << " " << x; } cout <<" }"; } cout << "\n"; } int main() { long long wys,dlu; cin >> wys >> dlu; long long obr; cin >> obr; vector<long long> obrazy; long long x,wsp1, wsp2,o; for(int i = 0; i < obr; i++) { cin >> x; obrazy.push_back(x); } vector<vector<long long>> prostokaty; vector<vector<long long>> tym; prostokaty.push_back({wys,dlu}); long long wynik = 0; for(int i = obrazy.size()-1; i>=0; i--) { o = obrazy[i]; for(auto prost: prostokaty) { wynik += (prost[0]/o)*(prost[1]/o); wsp1 = prost[0]%o; wsp2 = prost[1]%o; if(wsp1>0) { tym.push_back({wsp1,prost[1]-wsp2}); } if(wsp2>0) { tym.push_back({prost[0],wsp2}); } //cout <<"WYNIK: "<<wynik; } prostokaty.clear(); for(auto x: tym) { prostokaty.push_back(x); } tym.clear(); //print(prostokaty); if(prostokaty.size()==0) { break; } } if(prostokaty.size()>0) { cout << -1; } else { cout << wynik; } return 0; } |