因為每一列字元數固定,因此只需要根據字元在字串第i個位置mod n,就可以知道在第幾行。最後每一行字串逆序輸出,並補充最後一行的空格即可。
// 17'26"
#include <bits/stdc++.h>
using namespace std;
int main()
{
int n;
string emp;
cin >> n;
string s;
getline(cin,emp);
getline(cin,s);
vector<vector<char>> res(n);
for(int i = 0; i < s.size(); ++ i)
{
res[i % n].push_back(s[i]);
}
int col = res[0].size();
for(int i = 0; i < n; ++ i)
{
for(int j = 1; j <= col - (int)res[i].size(); ++ j)
cout << " ";
for(int j = res[i].size() - 1; j >= 0; -- j)
cout << res[i][j];
cout << endl;
}
return 0;
}