|  | 
|  | 1 | +#include <iostream> | 
|  | 2 | +#include <vector> | 
|  | 3 | +#include <algorithm> | 
|  | 4 | +#include <string> | 
|  | 5 | +#include <list> | 
|  | 6 | + | 
|  | 7 | +using namespace std; | 
|  | 8 | + | 
|  | 9 | +int main(void) | 
|  | 10 | +{ | 
|  | 11 | +	int n, m; | 
|  | 12 | +	cin >> n >> m; | 
|  | 13 | +	vector<string> qi(n); | 
|  | 14 | +	for (int i = 0; i < n; ++i) | 
|  | 15 | +	{ | 
|  | 16 | +		cin >> qi[i]; | 
|  | 17 | +	} | 
|  | 18 | +	vector<int> summ(n + 1, 0); | 
|  | 19 | +	vector<int> ob; | 
|  | 20 | +	ob.push_back(0); | 
|  | 21 | +	for (int i = 0; i < m; ++i) | 
|  | 22 | +	{ | 
|  | 23 | +		for (int j = 0; j < n; ++j) | 
|  | 24 | +		{ | 
|  | 25 | +			summ[j + 1] = summ[j]; | 
|  | 26 | +			if (qi[j][i] == 'o') summ[j + 1] = summ[j] + 1; | 
|  | 27 | +			else if (qi[j][i] == 'x') ob.push_back(j + 1); | 
|  | 28 | +		} | 
|  | 29 | +		if (ob.size() == 1) | 
|  | 30 | +		{ | 
|  | 31 | +			for (int k = 0; k < n; ++k) | 
|  | 32 | +			{ | 
|  | 33 | +				qi[k][i] = '.'; | 
|  | 34 | +			} | 
|  | 35 | +		} | 
|  | 36 | +		else | 
|  | 37 | +		{ | 
|  | 38 | +			for (int j = ob.back(); j < n; ++j) | 
|  | 39 | +			{ | 
|  | 40 | +				qi[j][i] = '.'; | 
|  | 41 | +			} | 
|  | 42 | +		} | 
|  | 43 | +		for (int j = ob.size() - 1; j > 0; --j) | 
|  | 44 | +		{ | 
|  | 45 | +			int box = summ[ob[j]] - summ[ob[j - 1]]; | 
|  | 46 | +			if (box == 0) continue; | 
|  | 47 | +			for (int k = ob[j] - 1; k > ob[j - 1]; --k) | 
|  | 48 | +			{ | 
|  | 49 | +				if (box) | 
|  | 50 | +				{ | 
|  | 51 | +					qi[k - 1][i] = 'o'; | 
|  | 52 | +					box -= 1; | 
|  | 53 | +				} | 
|  | 54 | +				else qi[k - 1][i] = '.'; | 
|  | 55 | +			} | 
|  | 56 | +		} | 
|  | 57 | +		ob.clear(); | 
|  | 58 | +		ob.push_back(0); | 
|  | 59 | +	} | 
|  | 60 | +	for (int i = 0; i < n; ++i) | 
|  | 61 | +	{ | 
|  | 62 | +		cout << qi[i] << endl; | 
|  | 63 | +	} | 
|  | 64 | +	return 0; | 
|  | 65 | +} | 
0 commit comments