L1-1 古风排版(20 分)

中国的古人写文字,是从右向左竖向排版的。本题就请你编写程序,把一段文字按古风排版。

输入格式:

输入在第一行给出一个正整数N(<100),是每一列的字符数。第二行给出一个长度不超过1000的非空字符串,以回车结束。

输出格式:

按古风格式排版给定的字符串,每列N个字符(除了最后一列可能不足N个)。

输入样例:

4
This is a test case

输出样例:

asa T
st ih
e tsi
 ce s

思路:1.输入记得防止被吃空格

   2.二维数组逆序来存字符串,一共有N行,那么就一共有strlen(str)/N 列,向上 取整

   3.注意,str的最后一个字符存完后要检查二维字符数组的第一列是否有N行,如果没有要用空格补齐

#include<iostream>
#include<cstdio>
#include<cstring>

using namespace std;
char Cmap[1005][1005];
int main()
{
  int n,m;
  char s[1005];
  cin >> n;
  getchar(); //用这个来接收空格 
  gets(s);
  int len = strlen(s);
  m = len/n;
  if(len%n != 0) m++; 
  int i = 0;
  for(int k = m-1; k >= 0; k--){
    for(int j = 0; j < n; j++){
      if(i < len)
        Cmap[j][k] = s[i++];
      else
        Cmap[j][k] = ' '; //当长度超过len时直接赋值空格。 
    }
  }
  for(int j = 0; j < n; j++){ // 最后输出。 
    for(int k = 0; k < m; k++)
      cout << Cmap[j][k];
    cout << endl;
  }
  return 0;
}
View Code

相关文章:

  • 2022-12-23
  • 2021-11-08
  • 2021-08-17
  • 2022-02-27
  • 2021-10-02
  • 2022-12-23
  • 2021-08-01
  • 2022-12-23
猜你喜欢
  • 2021-11-14
  • 2022-12-23
  • 2021-10-18
  • 2022-01-04
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案