Description
输入n(0<n≤10000)个浮点数,要求把这n个浮点数重新排列(并非排序,而是对齐)后再输出。每个浮点数中都有小数点且总长度不超过50位。
Input
第1行是一个正整数n(n≤10000),后面n行每行一个浮点数,每个浮点数中都保证小数点会出现。浮点数的长度不超过50位,注意这里的浮点数会超过系统标准浮点数的表示范围。
Output
n行,每行对应一个输入。要求每个浮点数的小数点在同一列上,同时要求首列上不会全部是空格。
Sample Input
2
-0.34345
4545.232
Sample Output
-0.34345
4545.232
解一:
#include<stdio.h>
#include<string.h>
int main(){
int n;
int i,j,s;
int m=0,max=0;
char a[10005][55];
int b[10005]={0};
char c[10055]={0};
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%s",&a[i]);
}
for(i=0;i<n;i++){
for(j=0;a[i][j]!='\0';j++){
if(a[i][j]=='.') m=j;
if(max<m) max=m;
}
b[i]=m;
for(j=0;j<10055;j++) c[j]=0;
}
for(i=0;i<n;i++){
if(b[i]<max){
s=max-b[i];
for(j=0;j<s;j++) c[j]=' ';
for(j=0;a[i][j]!='\0';j++,s++){
c[s]=a[i][j];
}
c[s]='\0';
printf("%s\n",c);
}
if(b[i]==max) printf("%s\n",a[i]);
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69390.html