古风排版 c语言


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

输入格式:

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

输出格式:

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

输入样例:

4
This is a test case

输出样例:

asa T
st ih
e tsi
 ce s
 
  • 时间限制:400ms
  • 内存限制:64MB
  • 代码长度限制:16kB
  • 判题程序:系统默认
  • 作者:陈越
  • 单位:浙江大学
题目判定
解题程序
  •                                                 
  •                                                 
  •                                                 
  •                                             
  • #include<stdio.h>
    #include<string.h>
    #include<stdlib.h>
    int main()
    {
    int N,n,m,i,j;//n为行,m为列
    int k=0;
    char s[100][1000];
    char str[1000];
    scanf("%d",&N);
    getchar();
    gets(str);//输入
    if(strlen(str)%N==0)
    m=strlen(str)/N;
    else
    m=(strlen(str)/N)+1;
    n=N;//行数是每列的字符数
    for(i=0;i<n;i++)
    s[i][0]=' ';
    for(j=m-1;j>=0;j--)
    {
    for(i=0;i<n;i++)//行
    {
    s[i][j]=str[k++];
    if(k==strlen(str))
    break;//当最后一个字符时跳出循环
    }
    }//输出古风排版的字符
    for(i=0;i<n;i++)
    {
    for(j=0;j<m;j++)
    putchar(s[i][j]);//输出整个以列的数字结束的字符
              if(i<n-1)
     putchar('\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、付费专栏及课程。

    余额充值