#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;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgppbnQgbiwgbTsKY2hhciBncmlkWzEwMDVdWzEwMDVdOwppbnQgdmlzWzEwMDVdWzEwMDVdOwppbnQgbGV2ZWxbMTAwNV1bMTAwNV07CnBhaXI8aW50LGludD4gcGFyWzEwMDVdWzEwMDVdOwoKdmVjdG9yPHBhaXI8aW50LCBpbnQ+PiBiID0ge3swLCAxfSwgezAsIC0xfSwgey0xLCAwfSwgezEsIDB9fTsKCmJvb2wgdmFsaWQoaW50IGksIGludCBqKSB7CiAgICByZXR1cm4gIShpIDwgMCB8fCBpID49IG4gfHwgaiA8IDAgfHwgaiA+PSBtIHx8IGdyaWRbaV1bal0gPT0gJyMnKTsKfQoKdm9pZCBiZnMoaW50IHNpLCBpbnQgc2opIHsKICAgIHF1ZXVlPHBhaXI8aW50LCBpbnQ+PiBxOwogICAgcS5wdXNoKHtzaSwgc2p9KTsKICAgIHZpc1tzaV1bc2pdID0gdHJ1ZTsKICAgIGxldmVsW3NpXVtzal0gPSAwOwoKICAgIHdoaWxlKCFxLmVtcHR5KCkpIHsKICAgICAgICBpbnQgcGkgPSBxLmZyb250KCkuZmlyc3Q7CiAgICAgICAgaW50IHBqID0gcS5mcm9udCgpLnNlY29uZDsKICAgICAgICBxLnBvcCgpOwoKICAgICAgICBmb3IgKGludCBpID0gMDsgaSA8IDQ7IGkrKykgewogICAgICAgICAgICBpbnQgY2kgPSBwaSArIGJbaV0uZmlyc3Q7CiAgICAgICAgICAgIGludCBjaiA9IHBqICsgYltpXS5zZWNvbmQ7CgogICAgICAgICAgICBpZih2YWxpZChjaSwgY2opICYmICF2aXNbY2ldW2NqXSkgewogICAgICAgICAgICAgICAgcS5wdXNoKHtjaSwgY2p9KTsKICAgICAgICAgICAgICAgIHZpc1tjaV1bY2pdID0gdHJ1ZTsKICAgICAgICAgICAgICAgIGxldmVsW2NpXVtjal0gPSBsZXZlbFtwaV1bcGpdICsgMTsKICAgICAgICAgICAgICAgIHBhcltjaV1bY2pdID0ge3BpLHBqfTsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgIH0KfQoKCgppbnQgbWFpbigpIHsKICAgIGNpbiA+PiBuID4+IG07CiAgICBpbnQgc2kgPSAtMSwgc2ogPSAtMSwgZGkgPSAtMSwgZGogPSAtMTsKCiAgICBtZW1zZXQodmlzLCBmYWxzZSwgc2l6ZW9mKHZpcykpOwogICAgbWVtc2V0KGxldmVsLCAtMSwgc2l6ZW9mKGxldmVsKSk7CiAgICBtZW1zZXQocGFyLCAtMSwgc2l6ZW9mKHBhcikpOwoKICAgIAoKCiAgICBmb3IoaW50IGkgPSAwOyBpIDwgbjsgaSsrKSB7CiAgICAgICAgZm9yKGludCBqID0gMDsgaiA8IG07IGorKykgewogICAgICAgICAgICBjaW4gPj4gZ3JpZFtpXVtqXTsKCiAgICAgICAgICAgIGlmKGdyaWRbaV1bal0gPT0gJ1InKSB7CiAgICAgICAgICAgICAgICBzaSA9IGk7CiAgICAgICAgICAgICAgICBzaiA9IGo7CiAgICAgICAgICAgIH0KCiAgICAgICAgICAgIGlmKGdyaWRbaV1bal0gPT0gJ0QnKSB7CiAgICAgICAgICAgICAgICBkaSA9IGk7CiAgICAgICAgICAgICAgICBkaiA9IGo7CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICB9CgoKICAgIGJmcyhzaSwgc2opOwoKICAgIHBhaXI8aW50LGludD4gZHN0ID0ge2RpLCBkan07CgogICAgd2hpbGUoZHN0LmZpcnN0ICE9IC0xICYmIGRzdC5zZWNvbmQgIT0gLTEpIHsKCiAgICAgICAgaWYoZ3JpZFtkc3QuZmlyc3RdW2RzdC5zZWNvbmRdICE9ICdSJyAmJiBncmlkW2RzdC5maXJzdF1bZHN0LnNlY29uZF0gIT0gJ0QnKSB7CiAgICAgICAgICAgIGdyaWRbZHN0LmZpcnN0XVtkc3Quc2Vjb25kXT0nWCc7CiAgICAgICAgfQogICAgICAgIAogICAgICAgIGRzdCA9IHBhcltkc3QuZmlyc3RdW2RzdC5zZWNvbmRdOwogICAgfQoKICAgIGZvcihpbnQgaSA9IDA7IGkgPCBuOyBpKyspIHsKICAgICAgICBmb3IoaW50IGogPSAwOyBqIDwgbTsgaisrKSB7CiAgICAgICAgICAgIGNvdXQgPDwgZ3JpZFtpXVtqXTsKICAgICAgICB9CiAgICAgICAgY291dCA8PCBlbmRsOwogICAgfQoKICAgIHJldHVybiAwOwp9Cg==