C语言对 typedef struct { //商品名字 char name[MAX_PRODUCTS]; //商品价格 double price; //商品数量 int quantity; //出售数量 int sellquantity; } Product; sellquantity 排序
时间: 2023-02-06 18:17:30 浏览: 116
在 C 语言中,可以使用 qsort 函数对 Product 类型的数组进行排序。qsort 函数需要提供一个比较函数作为参数,比较函数用于比较两个 Product 类型的变量的 sellquantity 字段的大小关系。
下面是一个示例代码:
```
#include <stdio.h>
#include <stdlib.h>
#define MAX_PRODUCTS 100
typedef struct {
char name[MAX_PRODUCTS];
double price;
int quantity;
int sellquantity;
} Product;
int compare_products(const void* a, const void* b)
{
Product* pa = (Product*)a;
Product* pb = (Product*)b;
return pa->sellquantity - pb->sellquantity;
}
int main()
{
// 定义并初始化一个 Product 类型的数组
Product products[] = {
{"Apple", 0.5, 10, 5},
{"Banana", 0.25, 20, 15},
{"Orange", 0.75, 5, 3},
{"Pear", 0.6, 8, 4}
};
int num_products = sizeof(products) / sizeof(Product);
// 使用 qsort 函数对数组进行排序
qsort(products, num_products, sizeof(Product), compare_products);
// 输出排序后的数组
for (int i = 0; i < num_products; i++) {
printf("%s\t%.2f\t%d\t%d\n", products[i].name, products[i].price, products[i].quantity, products[i].sellquantity);
}
return 0;
}
```
在上面的代码中,compare_products 函数是一个比较函数,它比较两个 Product 类型的变量的 sellquantity 字段的大小关系。qsort 函数接受四个参数:要排序的数组、数组的元素个数、数组中每个元素的大小、比较函数。在调用 qsort 函数时,传递
阅读全文