#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
int main()
{
char cast[50][100];
int n;
scanf("%d",&n);
getchar();//!!!!!!!!!!!!!!!!!!!!scanf输入后回车符进入缓冲区,用getchar()缓冲掉 不然回车符直接输入给gets=\0 直接break
int p=0;
while(p<50)//循环输入p-1行职员表行 1行空行
{
gets(cast[p++]);
if(cast[p-1][0]=='\0')break;//输入行为空时停止输入开始输出
}
int i,j;
int flag[50];//每行的冒号下标
int len[50];//每行的长度
for(i=0;i<p-1;i++)
{
len[i]=strlen(cast[i]);
//检错 printf("len=%d\n",len);
for(j=0;j<len[i];j++)
{
if(cast[i][j]==':')
{
flag[i]=j;//i行的冒号下标为j
//检错 printf("flag=%d\n",flag[i]);
break;
}
}
char jo[100],na[100];//输入的复制
char job[100],name[100];//存放结果
for(j=0;j<flag[i];j++)//复制职位
{
jo[j]=cast[i][j];
}
jo[j]='\0';
int t=0;
for(j=0;j<flag[i];j++)
{
if(jo[j]==' ')
{
job[t++]=jo[j];//若有空格 则只复制一个空格
while(jo[j]==' ')j++;//直到下一个不是空格
j--;//返回到最后一个空格处
}
else
{
job[t++]=jo[j];//复制职位
}
}
if(job[t-1]==' ')//!!!若最后有空格则删除最后的空格并加\0
job[t-1]='\0';
else job[t]='\0';//!!!!!!!!!!!!!!!!!!!若最后没有空格 也要加\0 不然出现烫 你懂得
//检错 printf("job=%s\n",job);
int k=0;
for(j=flag[i]+1;j<len[i];j++)//复制名字
{
na[k++]=cast[i][j];
}
na[k]='\0';
t=0;
for(j=0;j<k;j++)
{
if(na[j]==' '&&j==0)//除去开始的空格
{
while(na[j]==' ')j++;
j--;
continue;
}
if(na[j]==' ')//若有空格 则只复制一个空格
{
name[t++]=na[j];
while(na[j]==' ')j++;//直到下一个不是空格
j--;//返回到最后一个空格处
}
else
{
name[t++]=na[j];//复制姓名
}
}
if(name[t-1]==' ')//!!!若最后有空格则删除最后的空格并加\0
name[t-1]='\0';
else name[t]='\0';//!!!!!!!!!!!!!!!!!!!若最后没有空格 也要加\0 不然出现烫 你懂得
//检错 printf("name=%s\n",name);
//输出
printf("%*s : %-s\n",n-2,job,name);
/* printf("%-10d\n",101010); 左对齐
在打印数字宽度前面加一个“-”。
说明:数字宽度为10,如果要打印的位数小于10,则在右面补足空格;如果要打印的位数大于10,则打印所有的数字,不会截断。*/
/* printf("%10d",101010); 右对齐
在%和d之间加上数字宽度,就可以右对齐。
说明:数字宽度为10,如果要打印的位数小于10,左边补足空格;如果要打印的位数大于10,则打印所有的数字,不会截断。 */
/* printf("%.*s\n",int,str) ;
// %.*s 其中的.*表示显示的精度 对字符串输出(s)类型来说就是宽度
// 这个*代表的值由后面的参数列表中的整数型(int)值给出
// 例如:
printf("%.*s\n", 1, "abc"); // 输出a
printf("%.*s\n", 2, "abc"); // 输出ab
printf("%.*s\n", 3, "abc"); // 输出abc >3是一样的效果 因为输出类型type = s,遇到'\0'会结束 */
/* printf("%*s", 10, s);
意思是输出字符串s,但至少占10个位置,不足的在字符串s左边补空格,这里等同于printf("%10s", s);*/
}
return 0;
}
14-3
最新推荐文章于 2018-10-13 22:18:13 发布