解题思路:将正数和负数分开排序输出
注意事项:
参考代码:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int n[100],a[100][100],b[100][100],c[100][100];
int i=0,j;
while(1)
{
scanf("%d",&n[i]);
if(n[i]==0)//跳出循环的条件
break;
for(j=0;j<n[i];j++)//输入数据
scanf("%d",&a[i][j]);
i++;
}
int m=i,k=0,h[100],l=0,g[100];
for(i=0;i<m;i++)
{
for(j=0;j<n[i];j++)
{
if(a[i][j]<0)
{
b[i][k]=abs(a[i][j]);//取绝对值冰存储到b[100][100]中
k++;
}
else
{
c[i][l]=a[i][j];//将数据中整数部分存储到c[100][100]中
l++;
}
}
h[i]=k;//记下每组负数的个数
g[i]=l;//记下每组正数的个数
k=0;
l=0;
}
int t;
for(i=0;i<m;i++)//冒泡排序负数绝对值
{
for(j=0;j<h[i];j++)
{
for(k=0;k<h[i]-1-j;k++)
{
if(b[i][k]<b[i][k+1])
{
t=b[i][k];
b[i][k]=b[i][k+1];
b[i][k+1]=t;
}
}
}
}
for(i=0;i<m;i++)冒泡排序正数绝对值
{
for(j=0;j<g[i];j++)
{
for(k=0;k<g[i]-1-j;k++)
{
if(c[i][k]<c[i][k+1])
{
t=c[i][k];
c[i][k]=c[i][k+1];
c[i][k+1]=t;
}
}
}
}
for(i=0;i<m;i++)
{
for(j=0;j<h[i];j++)
{
printf("%d ",(-1)*b[i][j]);//先输出负数
}
for(j=0;j<g[i];j++)
{
printf("%d ",c[i][j]);//再输出正数
}
printf("\n");
}
return 0;
}
0.0分
2 人评分
2005年春浙江省计算机等级考试二级C 编程题(3),复杂度最低的方法没有之一!!!!!浏览:819 |
大神老白 (C语言代码)浏览:611 |
C语言程序设计教程(第三版)课后习题6.4 (C语言代码)浏览:553 |
打水问题 (C语言代码)浏览:1072 |
大家好,我是验题君浏览:577 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:407 |
Quadratic Equation (C语言代码)浏览:988 |
1231题解(注意理解“输入多个测试实例”)浏览:788 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:691 |
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:699 |