#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <ctype.h>
#include <math.h>
#include <stack>
#include <queue>
#include <map>
#include <set>
#include <vector>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std;
#define ll long long
#define ls rt<<1
#define rs ls1
#define lson l,mid,ls
#define rson mid+1,r,rs
#define middle (l+r)>>1
#define eps (1e-9)
#define type int
#define clr_all(x,c) memset(x,c,sizeof(x))
#define clr(x,c,n) memset(x,c,sizeof(x[0])*(n+1))
#define MOD 1000000007
#define inf 0x3f3f3f3f
#define pi acos(-1.0)
#define M 1000+5
char s[M][M];
int len[M];
int main(){
int mx=0,n,i=0,k,j,t,flag,x;
while(gets(s[i])){
len[i]=strlen(s[i]);
if(len[i]>mx)mx=len[i];
i++;
}
for(k=0;k<mx+2;k++)putchar('*');
puts("");
flag=0;
for(k=0;k<i;k++){
putchar('*');
j=mx-len[k];
if(j%2==0){
for(t=0;t<j/2;t++)putchar(' ');
for(t=0;t<len[k];t++)putchar(s[k][t]);
for(t=0;t<j/2;t++)putchar(' ');
}else{
if(flag%2==0){
for(t=0;t<j/2;t++)putchar(' ');
for(t=0;t<len[k];t++)putchar(s[k][t]);
for(t=0;t<(j+1)/2;t++)putchar(' ');
}else{
for(t=0;t<(j+1)/2;t++)putchar(' ');
for(t=0;t<len[k];t++)putchar(s[k][t]);
for(t=0;t<j/2;t++)putchar(' ');
}
flag++;
}
putchar('*');
puts("");
}
for(k=0;k<mx+2;k++)putchar('*');
puts("");
return 0;
}
#include <string.h>
#include <stdio.h>
#include <ctype.h>
#include <math.h>
#include <stack>
#include <queue>
#include <map>
#include <set>
#include <vector>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std;
#define ll long long
#define ls rt<<1
#define rs ls1
#define lson l,mid,ls
#define rson mid+1,r,rs
#define middle (l+r)>>1
#define eps (1e-9)
#define type int
#define clr_all(x,c) memset(x,c,sizeof(x))
#define clr(x,c,n) memset(x,c,sizeof(x[0])*(n+1))
#define MOD 1000000007
#define inf 0x3f3f3f3f
#define pi acos(-1.0)
#define M 1000+5
char s[M][M];
int len[M];
int main(){
int mx=0,n,i=0,k,j,t,flag,x;
while(gets(s[i])){
len[i]=strlen(s[i]);
if(len[i]>mx)mx=len[i];
i++;
}
for(k=0;k<mx+2;k++)putchar('*');
puts("");
flag=0;
for(k=0;k<i;k++){
putchar('*');
j=mx-len[k];
if(j%2==0){
for(t=0;t<j/2;t++)putchar(' ');
for(t=0;t<len[k];t++)putchar(s[k][t]);
for(t=0;t<j/2;t++)putchar(' ');
}else{
if(flag%2==0){
for(t=0;t<j/2;t++)putchar(' ');
for(t=0;t<len[k];t++)putchar(s[k][t]);
for(t=0;t<(j+1)/2;t++)putchar(' ');
}else{
for(t=0;t<(j+1)/2;t++)putchar(' ');
for(t=0;t<len[k];t++)putchar(s[k][t]);
for(t=0;t<j/2;t++)putchar(' ');
}
flag++;
}
putchar('*');
puts("");
}
for(k=0;k<mx+2;k++)putchar('*');
puts("");
return 0;
}
本文介绍了一个使用C++实现的程序,该程序能够读取多行输入,并将每行字符串居中输出到星号边界的矩形框内。程序通过计算最长字符串长度来确定边界宽度,并对所有字符串进行居中对齐处理。
1808

被折叠的 条评论
为什么被折叠?



