//problem 4
#include <bits/stdc++.h>
using namespace std;
int n, m;
char grid[1005][1005];
int vis[1005][1005];
int level[1005][1005];
pair<int,int> par[1005][1005];
vector<pair<int, int>> b = {{0, 1}, {0, -1}, {-1, 0}, {1, 0}};
bool valid(int i, int j) {
return !(i < 0 || i >= n || j < 0 || j >= m || grid[i][j] == '#');
}
void bfs(int si, int sj) {
queue<pair<int, int>> q;
q.push({si, sj});
vis[si][sj] = true;
level[si][sj] = 0;
while(!q.empty()) {
int pi = q.front().first;
int pj = q.front().second;
q.pop();
for (int i = 0; i < 4; i++) {
int ci = pi + b[i].first;
int cj = pj + b[i].second;
if(valid(ci, cj) && !vis[ci][cj]) {
q.push({ci, cj});
vis[ci][cj] = true;
level[ci][cj] = level[pi][pj] + 1;
par[ci][cj] = {pi,pj};
}
}
}
}
int main() {
cin >> n >> m;
int si = -1, sj = -1, di = -1, dj = -1;
memset(vis, false, sizeof(vis));
memset(level, -1, sizeof(level));
memset(par, -1, sizeof(par));
for(int i = 0; i < n; i++) {
for(int j = 0; j < m; j++) {
cin >> grid[i][j];
if(grid[i][j] == 'R') {
si = i;
sj = j;
}
if(grid[i][j] == 'D') {
di = i;
dj = j;
}
}
}
bfs(si, sj);
pair<int,int> dst = {di, dj};
while(dst.first != -1 && dst.second != -1) {
if(grid[dst.first][dst.second] != 'R' && grid[dst.first][dst.second] != 'D') {
grid[dst.first][dst.second]='X';
}
dst = par[dst.first][dst.second];
}
for(int i = 0; i < n; i++) {
for(int j = 0; j < m; j++) {
cout << grid[i][j];
}
cout << endl;
}
return 0;
}
Ly9wcm9ibGVtIDQKCiNpbmNsdWRlIDxiaXRzL3N0ZGMrKy5oPgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKaW50IG4sIG07CmNoYXIgZ3JpZFsxMDA1XVsxMDA1XTsKaW50IHZpc1sxMDA1XVsxMDA1XTsKaW50IGxldmVsWzEwMDVdWzEwMDVdOwpwYWlyPGludCxpbnQ+IHBhclsxMDA1XVsxMDA1XTsKCnZlY3RvcjxwYWlyPGludCwgaW50Pj4gYiA9IHt7MCwgMX0sIHswLCAtMX0sIHstMSwgMH0sIHsxLCAwfX07Cgpib29sIHZhbGlkKGludCBpLCBpbnQgaikgewogICAgcmV0dXJuICEoaSA8IDAgfHwgaSA+PSBuIHx8IGogPCAwIHx8IGogPj0gbSB8fCBncmlkW2ldW2pdID09ICcjJyk7Cn0KCnZvaWQgYmZzKGludCBzaSwgaW50IHNqKSB7CiAgICBxdWV1ZTxwYWlyPGludCwgaW50Pj4gcTsKICAgIHEucHVzaCh7c2ksIHNqfSk7CiAgICB2aXNbc2ldW3NqXSA9IHRydWU7CiAgICBsZXZlbFtzaV1bc2pdID0gMDsKCiAgICB3aGlsZSghcS5lbXB0eSgpKSB7CiAgICAgICAgaW50IHBpID0gcS5mcm9udCgpLmZpcnN0OwogICAgICAgIGludCBwaiA9IHEuZnJvbnQoKS5zZWNvbmQ7CiAgICAgICAgcS5wb3AoKTsKCiAgICAgICAgZm9yIChpbnQgaSA9IDA7IGkgPCA0OyBpKyspIHsKICAgICAgICAgICAgaW50IGNpID0gcGkgKyBiW2ldLmZpcnN0OwogICAgICAgICAgICBpbnQgY2ogPSBwaiArIGJbaV0uc2Vjb25kOwoKICAgICAgICAgICAgaWYodmFsaWQoY2ksIGNqKSAmJiAhdmlzW2NpXVtjal0pIHsKICAgICAgICAgICAgICAgIHEucHVzaCh7Y2ksIGNqfSk7CiAgICAgICAgICAgICAgICB2aXNbY2ldW2NqXSA9IHRydWU7CiAgICAgICAgICAgICAgICBsZXZlbFtjaV1bY2pdID0gbGV2ZWxbcGldW3BqXSArIDE7CiAgICAgICAgICAgICAgICBwYXJbY2ldW2NqXSA9IHtwaSxwan07CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICB9Cn0KCgoKaW50IG1haW4oKSB7CiAgICBjaW4gPj4gbiA+PiBtOwogICAgaW50IHNpID0gLTEsIHNqID0gLTEsIGRpID0gLTEsIGRqID0gLTE7CgogICAgbWVtc2V0KHZpcywgZmFsc2UsIHNpemVvZih2aXMpKTsKICAgIG1lbXNldChsZXZlbCwgLTEsIHNpemVvZihsZXZlbCkpOwogICAgbWVtc2V0KHBhciwgLTEsIHNpemVvZihwYXIpKTsKCiAgICAKCgogICAgZm9yKGludCBpID0gMDsgaSA8IG47IGkrKykgewogICAgICAgIGZvcihpbnQgaiA9IDA7IGogPCBtOyBqKyspIHsKICAgICAgICAgICAgY2luID4+IGdyaWRbaV1bal07CgogICAgICAgICAgICBpZihncmlkW2ldW2pdID09ICdSJykgewogICAgICAgICAgICAgICAgc2kgPSBpOwogICAgICAgICAgICAgICAgc2ogPSBqOwogICAgICAgICAgICB9CgogICAgICAgICAgICBpZihncmlkW2ldW2pdID09ICdEJykgewogICAgICAgICAgICAgICAgZGkgPSBpOwogICAgICAgICAgICAgICAgZGogPSBqOwogICAgICAgICAgICB9CiAgICAgICAgfQogICAgfQoKCiAgICBiZnMoc2ksIHNqKTsKCiAgICBwYWlyPGludCxpbnQ+IGRzdCA9IHtkaSwgZGp9OwoKICAgIHdoaWxlKGRzdC5maXJzdCAhPSAtMSAmJiBkc3Quc2Vjb25kICE9IC0xKSB7CgogICAgICAgIGlmKGdyaWRbZHN0LmZpcnN0XVtkc3Quc2Vjb25kXSAhPSAnUicgJiYgZ3JpZFtkc3QuZmlyc3RdW2RzdC5zZWNvbmRdICE9ICdEJykgewogICAgICAgICAgICBncmlkW2RzdC5maXJzdF1bZHN0LnNlY29uZF09J1gnOwogICAgICAgIH0KICAgICAgICAKICAgICAgICBkc3QgPSBwYXJbZHN0LmZpcnN0XVtkc3Quc2Vjb25kXTsKICAgIH0KCiAgICBmb3IoaW50IGkgPSAwOyBpIDwgbjsgaSsrKSB7CiAgICAgICAgZm9yKGludCBqID0gMDsgaiA8IG07IGorKykgewogICAgICAgICAgICBjb3V0IDw8IGdyaWRbaV1bal07CiAgICAgICAgfQogICAgICAgIGNvdXQgPDwgZW5kbDsKICAgIH0KCiAgICByZXR1cm4gMDsKfQo=