解题思路:将正数和负数分开排序输出
注意事项:
参考代码:
#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分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复