古风排版 c语言

来源:互联网 发布:tomcat启动 记录数据库 编辑:程序博客网 时间:2024/04/29 14:58

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

输入格式:

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

输出格式:

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

输入样例:

4This is a test case

输出样例:

asa Tst ihe 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;
}


原创粉丝点击