#include <iostream>
using namespace std;
int tab[2000][2000];
int lista[3][10000000];
int main () {
ios_base::sync_with_stdio(false);
cin.tie(0);
int n, m, k, x, y, l=1, S;
long long int a, b;
pair <long long int, long long int> wynik;
char ch;
cin>>n>>m>>k;
for(int i=0; i<n; i++) {
for(int j=0; j<m; j++) {
cin>>ch;
if(ch=='X') tab[i][j]=-1;
}
}
lista[0][0]=n-1;
lista[1][0]=m-1;
for(int i=0; true; i++) {
if(lista[1][i]<m-1) {
if(tab[lista[0][i]][lista[1][i]+1]==0) {
lista[0][l]=lista[0][i];
lista[1][l]=lista[1][i]+1;
lista[2][l]=lista[2][i]+1;
l++;
tab[lista[0][i]][lista[1][i]+1]=-1;
}
}
if(lista[1][i]>0) {
if(tab[lista[0][i]][lista[1][i]-1]==0) {
lista[0][l]=lista[0][i];
lista[1][l]=lista[1][i]-1;
lista[2][l]=lista[2][i]+1;
tab[lista[0][i]][lista[1][i]-1]=-1;
if(lista[0][l]==0 && lista[1][l]==0) {
S=lista[2][l];
break;
}
l++;
}
}
if(lista[0][i]<n-1) {
if(tab[lista[0][i]+1][lista[1][i]]==0) {
lista[0][l]=lista[0][i]+1;
lista[1][l]=lista[1][i];
lista[2][l]=lista[2][i]+1;
l++;
tab[lista[0][i]+1][lista[1][i]]=-1;
}
}
if(lista[0][i]>0) {
if(tab[lista[0][i]-1][lista[1][i]]==0) {
lista[0][l]=lista[0][i]-1;
lista[1][l]=lista[1][i];
lista[2][l]=lista[2][i]+1;
tab[lista[0][i]-1][lista[1][i]]=-1;
if(lista[0][l]==0 && lista[1][l]==0) {
S=lista[2][l];
break;
}
l++;
}
}
}
y=(S-(m+n-2))/2;
x=S-y;
cin>>a>>b;
wynik.first=a*x+b*y;
wynik.second=1;
for(int i=1; i<k; i++) {
cin>>a>>b;
if(a*x+b*y<wynik.first) {
wynik.first=a*x+b*y;
wynik.second=1;
}
else if(a*x+b*y==wynik.first) {
wynik.second++;
}
}
cout<<wynik.first<<" "<<wynik.second;
}
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 73 74 75 76 77 78 79 80 81 82 83 | #include <iostream> using namespace std; int tab[2000][2000]; int lista[3][10000000]; int main () { ios_base::sync_with_stdio(false); cin.tie(0); int n, m, k, x, y, l=1, S; long long int a, b; pair <long long int, long long int> wynik; char ch; cin>>n>>m>>k; for(int i=0; i<n; i++) { for(int j=0; j<m; j++) { cin>>ch; if(ch=='X') tab[i][j]=-1; } } lista[0][0]=n-1; lista[1][0]=m-1; for(int i=0; true; i++) { if(lista[1][i]<m-1) { if(tab[lista[0][i]][lista[1][i]+1]==0) { lista[0][l]=lista[0][i]; lista[1][l]=lista[1][i]+1; lista[2][l]=lista[2][i]+1; l++; tab[lista[0][i]][lista[1][i]+1]=-1; } } if(lista[1][i]>0) { if(tab[lista[0][i]][lista[1][i]-1]==0) { lista[0][l]=lista[0][i]; lista[1][l]=lista[1][i]-1; lista[2][l]=lista[2][i]+1; tab[lista[0][i]][lista[1][i]-1]=-1; if(lista[0][l]==0 && lista[1][l]==0) { S=lista[2][l]; break; } l++; } } if(lista[0][i]<n-1) { if(tab[lista[0][i]+1][lista[1][i]]==0) { lista[0][l]=lista[0][i]+1; lista[1][l]=lista[1][i]; lista[2][l]=lista[2][i]+1; l++; tab[lista[0][i]+1][lista[1][i]]=-1; } } if(lista[0][i]>0) { if(tab[lista[0][i]-1][lista[1][i]]==0) { lista[0][l]=lista[0][i]-1; lista[1][l]=lista[1][i]; lista[2][l]=lista[2][i]+1; tab[lista[0][i]-1][lista[1][i]]=-1; if(lista[0][l]==0 && lista[1][l]==0) { S=lista[2][l]; break; } l++; } } } y=(S-(m+n-2))/2; x=S-y; cin>>a>>b; wynik.first=a*x+b*y; wynik.second=1; for(int i=1; i<k; i++) { cin>>a>>b; if(a*x+b*y<wynik.first) { wynik.first=a*x+b*y; wynik.second=1; } else if(a*x+b*y==wynik.first) { wynik.second++; } } cout<<wynik.first<<" "<<wynik.second; } |
English