PTA 7-6-1 古风排版

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

输入格式:

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

输出格式:

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

输入样例:

4
This is a test case

输出样例:

asa T
st ih
e tsi
 ce s

#include<stdio.h>
#include<string.h>
int main(){
int n;
   scanf("%d\n",&n);
    char a[100];
   for(int i=0;i<100;i++){scanf("%c",&a[i]);}
    int t;
    if(strlen(a)%n==0)t=strlen(a)/n-1;
    else t=(strlen(a)/n);
    printf("%d\n",strlen(a));
    for(int j=0;j<n;j++ ){
    for(int i=n*(t-1)+j;i>=0;i-=n)
    {    if(i<strlen(a)-3&&i>=0)
           printf("%c",a[i]);
     else printf(" ");
    } printf("\n");}
    return 0;
}

PTA平台上有古风排版相关题目,如题目要求按古风格式排版给定的字符串,每列N个字符(除最后一列可能不足N个)。示例如下: - 输入样例:`4 This is a test case` - 输出样例:`asa T st ih e tsi ce s` [^1][^2] 以下是该题目的C语言解答代码: ```c #include <stdio.h> #include <string.h> int main() { int n = 0; char ch[1006] = {0}; scanf("%d", &n); // n其实可以表示行数 getchar(); gets(ch); int len = strlen(ch); // 字符串长度 int line = len / n; // 算出有几列 if (line * n < len) line++; for (int i = 0; i < n; i++) { for (int j = line - 1; j >= 0; j--) { if (ch[n * j + i] == '\0' || (n * j + i) > len) { // 这里进行一些特殊的处理,将超出的索引与'\0'变成空格 printf(" "); continue; } printf("%c", ch[n * j + i]); } printf("\n"); } return 0; } ``` 此代码中,`n`表示每列的字符数(即行数),通过计算字符串长度和列数,利用双重循环输出排版后的字符串。在输出过程中,对超出索引和空字符的情况做了特殊处理,将其转换为空格输出 [^2]。 另外,还有C++的相关解答涉及输出转置后的字符串,通过两层循环按列输出字符,外循环遍历每一列,内循环遍历每一行,并在每列输出完后换行: ```cpp for(int i = 0; i < n; i++) { for (int j = 0; j < l; j++) { cout << arr[i][j]; } cout << endl; } ``` [^4] 还有关于字符赋值的代码片段,将输入字符串按古风排版规则赋值到二维数组中: ```cpp int index = 0; for (int j = cols - 1; j >= 0; j--) { for (int i = 0; i < n; i++) { if (index < len) { output[i][j] = str[index++]; } else { break; } } } ``` [^5]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值