输入n(n≤100)个整数,按照绝对值从大到小排序后输出。c语言数组
时间: 2023-09-26 15:14:20 浏览: 95
声明和输入部分代码示例:
```c
#include <stdio.h>
#include <stdlib.h>
int cmp(const void* a, const void* b) {
return abs(*(int*)b) - abs(*(int*)a); // 从大到小排序
}
int main() {
int n, arr[100];
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]); // 输入n个整数
}
qsort(arr, n, sizeof(int), cmp); // 排序
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]); // 输出排序结果
}
return 0;
}
```
相关问题
C语言用数组输入n ( n <=100)个整数,按照绝对值从大到小排序后输出。
好的,这个问题属于计算机科学问题,可以回答。以下为C语言的代码实现:
```c
#include <stdio.h>
#include <stdlib.h>
#define N 100
int cmp(const void *a, const void *b) {
int x = *(int *)a;
int y = *(int *)b;
return abs(y) - abs(x);
}
int main() {
int n, nums[N];
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%d", &nums[i]);
}
qsort(nums, n, sizeof(int), cmp);
for (int i = 0; i < n; i++) {
printf("%d ", nums[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即可。