L1-039 古风排版——C语言

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

输入格式:

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

输出格式:

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

乍一看这道题,你也许不知道从何入手,不知道如何按照规则顺序打印。

其实这道题非常简单。

  •  我们可以事先把字符串放入一个二维数组中,每一行都对应一个单词。
  • 如果把二维数组以行和列的方式排列,那么你会发现这就是一个矩阵。
  • 即使题目说“每列N个字符(除了最后一列可能不足N个)”,其实就是不足的地方用空格补齐,直到形成一个完整矩阵的样子。
  • 最后打印的时候,只要将行和列反过来打印就行了。

这么说,你应该就明白了。那么直接上代码。

#include 

int main(void)
{
    int N;
    int i, j;
    char buffer[1001], test[1001][100];
    char* ptr = buffer;
    int tmp;

    scanf("%d", &N);
    getchar();//读取最后的换行符,防止对下面的getchar()函数造成干扰
    gets(buffer);
    for (i = 0; *ptr; i++)//将字符全部放入二维数组中
    {
        for (j = 0; j < N; j++)
        {
            if (*ptr == 0)
            {
                test[i][j] = ' ';//最后字符全部放完了,剩下用空格填补直到字符形状是一个矩阵
                continue;
            }
            test[i][j] = *ptr++;
        }
    }
    i = i - 1;
    for (j = 0; j < N; j++)//以行和列翻转的方式输出
    {
        for (tmp = i; tmp >= 0; tmp--)
        {
            printf("%c", test[tmp][j]);
        }
        printf("\n");
    }
    return 0;
}

 你自己就是座金矿,关键是看如何发掘和重用自己——苏格拉底

你可能感兴趣的:(c语言,开发语言)