第三题,排版题。输入若干行字符,表示某电影的演职员表,每行只有一个冒号,冒号前面是职位,冒号后面是姓名,要求把各行冒号对齐,删除多余空格后输出。先输入一个数字,表示排版要求的冒号位置,该位置号保证比各行冒号前的最大字符数还要大。再输入若干行字符,最多50行,每行最多100个字符,除空格、制表符和回车之外都是有效字符,要求每行的冒号处于格式要求的位置,冒号两边与有效单词之间各有一个空格,冒号前面的单词之间只有一个空格(删除多余的空格和制表符),在冒号左边右对齐,前面全由空格填充,冒号后面的单词之间也只有一个空格,在冒号右边左对齐,最后一个单词后不加空格直接换行。
解题:主要是要弄出前面要打出多少空格!假设给的指定‘’:‘’的位置是n,在给定的字符串中‘:’的位置是loc,那么就在先打印出n-2-loc个空格,然后按格式输出即可。
#include <cstdio>
#include <string.h>
#define maxn 105
int main()
{
int n ;
scanf("%d",&n);
char s[maxn] ;
while ( scanf("%s",s) )
{
int loc = 0 ;
for ( int i = 0 ; i < strlen(s) ; i ++)
{
if( s[i] == ':')
{
loc = i;
break;
}
}
for ( int i = 0 ; i < n - 2 - loc ; i ++ )
printf(" ");
for ( int i = 0 ; i < loc ; i++ )
printf("%c",s[i]);
printf(" : ");
for ( int i = loc + 1 ; i < strlen(s); i ++ )
printf("%c",s[i]);
printf("\n");
}
return 0 ;
}