中国的古人写文字,是从右向左竖向排版的。本题就请你编写程序,把一段文字按古风排版。
输入格式:
输入在第一行给出一个正整数N(<100),是每一列的字符数。第二行给出一个长度不超过1000的非空字符串,以回车结束。
输出格式:
按古风格式排版给定的字符串,每列N个字符(除了最后一列可能不足N个)。
乍一看这道题,你也许不知道从何入手,不知道如何按照规则顺序打印。
其实这道题非常简单。
- 我们可以事先把字符串放入一个二维数组中,每一行都对应一个单词。
- 如果把二维数组以行和列的方式排列,那么你会发现这就是一个矩阵。
- 即使题目说“每列N个字符(除了最后一列可能不足N个)”,其实就是不足的地方用空格补齐,直到形成一个完整矩阵的样子。
- 最后打印的时候,只要将行和列反过来打印就行了。
这么说,你应该就明白了。那么直接上代码。
#include <stdio.h>
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;
}
你自己就是座金矿,关键是看如何发掘和重用自己——苏格拉底
标签:tmp,++,C语言,int,039,L1,test,排版,ptr From: https://blog.csdn.net/m0_74748762/article/details/141639360