c语言编写输入n(n<=100)个整数,按照绝对值从大到小排序后输出。题目保证对于每一个测试实例,所有数的绝对值都不相等。
时间: 2023-09-26 18:14:55 浏览: 146
可以直接使用C语言的qsort函数来排序,排序的规则是绝对值从大到小。具体代码如下:
#include <stdio.h>
#include <stdlib.h>
#define MAX_N 100
int cmp(const void *a, const void *b)
{
int abs_a = abs(*((int*)a));
int abs_b = abs(*((int*)b));
return abs_b - abs_a;
}
int main()
{
int n;
int a[MAX_N];
scanf("%d", &n);
for (int i = 0; i < n; ++i)
{
scanf("%d", &a[i]);
}
qsort(a, n, sizeof(int), cmp);
for (int i = 0; i < n; ++i)
{
printf("%d ", a[i]);
}
printf("\n");
return 0;
}
当然,这段代码有许多可以优化的地方,但是按照题目要求,这样实现就够了。
相关问题
c语言编写输入n(n<=100)个整数,按照绝对值从大到小排序后输出。
好的,这是一个关于编程的问题。这个问题需要用到冒泡排序法,需要注意绝对值大小的判断。下面是示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
int main()
{
int n, arr[100], i, j, temp;
scanf("%d", &n);
for (i = 0; i < n; ++i)
{
scanf("%d", &arr[i]);
}
for (i = 0; i < n - 1; ++i)
{
for (j = i + 1; j < n; ++j)
{
if (abs(arr[i]) < abs(arr[j]))
{
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
for (i = 0; i < n; ++i)
{
printf("%d ", arr[i]);
}
return 0;
}
```
希望这个程序能够帮到你。如果还有其他问题,欢迎随时提出。
C语言程序 输入 n ( n <=100)个整数,按照绝对值从大到小排序后输出。
好的,这是一个C语言的问题,可以回答。以下是示例代码:
```
#include <stdio.h>
#include <stdlib.h>
int cmp(int *a, int *b) {
if (abs(*a) < abs(*b)) return 1;
if (abs(*a) > abs(*b)) return -1;
return 0;
}
int main() {
int n, i;
scanf("%d", &n);
int *a = (int *)malloc(sizeof(int) * n);
for (i = 0; i < n; ++i) {
scanf("%d", &a[i]);
}
qsort(a, n, sizeof(int), cmp);
for (i = 0; i < n; ++i) {
printf("%d ", a[i]);
}
free(a);
return 0;
}
```
解释一下:首先输入一个整数n,表示要输入n个整数;然后用动态内存分配(malloc)分配一个长度为n的整数数组a,并输入n个整数存入数组a中;接着使用qsort函数对数组a进行排序,排序规则是按照元素绝对值从大到小排序,这里使用了一个自定义的比较函数cmp;最后循环输出排序后的数组a即可。