解题思路:用动态内存分配。
注意事项:循环条件要用scanf("%d",&n)!=EOF。
参考代码:
#include<stdio.h>
#include<malloc.h>
#include <stdlib.h>
int main () {
int n,temp1,temp2,*p;
int c;
while(scanf("%d",&n)!=EOF){
if(n==0)
break;
else{
p=(int *)malloc(n*sizeof(int));
for(int i=0;i<n;i++){
scanf("%d",(p+i));
}
for(int j=0;j<n-1;++j){
for(int k=0;k<n-1-j;++k){
temp1=abs(*(p+k));
temp2=abs(*(p+k+1));
if(temp1<temp2)
c=*(p+k),*(p+k)=*(p+k+1),*(p+k+1)=c;
}
}
for(int e=0;e<n;e++)
printf("%d ",*(p+e));
printf("\n");
free(p);
}
}
}
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复