鱼C论坛

 找回密码
 立即注册
查看: 666|回复: 5

[已解决]关于结构体数组排序

[复制链接]
发表于 2023-12-15 16:32:36 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
struct k{
         int a;
         int b;
         int c;
         int d;
}pep[10]={
                {2,3,5,4},
                {4,5,7,8},
                {1,2,3,4},
                {7,8,9,10},
                { 3,2,1,0},
                {0,7,4,1},
                {2,2,2,2},
                {6,6,6,6},
                {8,8,8,8},
                {10,10,10,10},
};
定义了十个结构体数组,要求按照“d”的大小 从大到小依次输出
求解答


最佳答案
2023-12-15 16:33:18
要按照结构体数组中的d值从大到小进行排序,可以使用冒泡排序或者快速排序算法。下面的示例代码演示了如何使用冒泡排序对结构体数组进行排序:
  1. #include <stdio.h>
  2. // 定义结构体
  3. struct k{
  4.     int a;
  5.     int b;
  6.     int c;
  7.     int d;
  8. };
  9. int main() {
  10.     struct k pep[] = {
  11.         {2,3,5,4},
  12.         {4,5,7,8},
  13.         {1,2,3,4},
  14.         {7,8,9,10},
  15.         {3,2,1,0},
  16.         {0,7,4,1},
  17.         {2,2,2,2},
  18.         {6,6,6,6},
  19.         {8,8,8,8},
  20.         {10,10,10,10}
  21.     };
  22.    
  23.     int n = sizeof(pep) / sizeof(struct k);  // 计算结构体数组的长度
  24.    
  25.     // 使用冒泡排序按照d的大小进行排序
  26.     for (int i = 0; i < n-1; i++) {
  27.         for (int j = 0; j < n-1-i; j++) {
  28.             if (pep[j].d < pep[j+1].d) {
  29.                 // 交换两个结构体的位置
  30.                 struct k temp = pep[j];
  31.                 pep[j] = pep[j+1];
  32.                 pep[j+1] = temp;
  33.             }
  34.         }
  35.     }
  36.    
  37.     // 输出排序后的结果
  38.     for (int i = 0; i < n; i++) {
  39.         printf("%d\n", pep[i].d);
  40.     }
  41.    
  42.     return 0;
  43. }
复制代码

希望这个例子能对你有所帮助!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-12-15 16:33:18 | 显示全部楼层    本楼为最佳答案   
要按照结构体数组中的d值从大到小进行排序,可以使用冒泡排序或者快速排序算法。下面的示例代码演示了如何使用冒泡排序对结构体数组进行排序:
  1. #include <stdio.h>
  2. // 定义结构体
  3. struct k{
  4.     int a;
  5.     int b;
  6.     int c;
  7.     int d;
  8. };
  9. int main() {
  10.     struct k pep[] = {
  11.         {2,3,5,4},
  12.         {4,5,7,8},
  13.         {1,2,3,4},
  14.         {7,8,9,10},
  15.         {3,2,1,0},
  16.         {0,7,4,1},
  17.         {2,2,2,2},
  18.         {6,6,6,6},
  19.         {8,8,8,8},
  20.         {10,10,10,10}
  21.     };
  22.    
  23.     int n = sizeof(pep) / sizeof(struct k);  // 计算结构体数组的长度
  24.    
  25.     // 使用冒泡排序按照d的大小进行排序
  26.     for (int i = 0; i < n-1; i++) {
  27.         for (int j = 0; j < n-1-i; j++) {
  28.             if (pep[j].d < pep[j+1].d) {
  29.                 // 交换两个结构体的位置
  30.                 struct k temp = pep[j];
  31.                 pep[j] = pep[j+1];
  32.                 pep[j+1] = temp;
  33.             }
  34.         }
  35.     }
  36.    
  37.     // 输出排序后的结果
  38.     for (int i = 0; i < n; i++) {
  39.         printf("%d\n", pep[i].d);
  40.     }
  41.    
  42.     return 0;
  43. }
复制代码

希望这个例子能对你有所帮助!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-12-15 16:37:55 | 显示全部楼层
FishC 发表于 2023-12-15 16:33
要按照结构体数组中的d值从大到小进行排序,可以使用冒泡排序或者快速排序算法。下面的示例代码演示了如何 ...

我刚刚没有说清楚,是要求按照“d”的大小,从大到小输出整个数组
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-12-15 16:38:17 | 显示全部楼层
-kasha 发表于 2023-12-15 16:37
我刚刚没有说清楚,是要求按照“d”的大小,从大到小 ...

非常抱歉理解错误。如果要按照结构体数组中的 d 值从大到小输出整个数组,可以使用标准库函数 `qsort` 来排序。下面是示例代码:
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. // 定义结构体
  4. struct k{
  5.     int a;
  6.     int b;
  7.     int c;
  8.     int d;
  9. };
  10. // 比较函数,用于 qsort 排序
  11. int compare(const void *a, const void *b) {
  12.     return ((struct k *)b)->d - ((struct k *)a)->d; // 从大到小排序
  13. }
  14. int main() {
  15.     struct k pep[] = {
  16.         {2,3,5,4},
  17.         {4,5,7,8},
  18.         {1,2,3,4},
  19.         {7,8,9,10},
  20.         {3,2,1,0},
  21.         {0,7,4,1},
  22.         {2,2,2,2},
  23.         {6,6,6,6},
  24.         {8,8,8,8},
  25.         {10,10,10,10}
  26.     };
  27.     int n = sizeof(pep) / sizeof(struct k);  // 计算结构体数组的长度
  28.     // 使用 qsort 函数按照 d 的大小进行排序
  29.     qsort(pep, n, sizeof(struct k), compare);
  30.     // 输出排序后的结果
  31.     for (int i = 0; i < n; i++) {
  32.         printf("a = %d, b = %d, c = %d, d = %d\n", pep[i].a, pep[i].b, pep[i].c, pep[i].d);
  33.     }
  34.     return 0;
  35. }
复制代码

这段代码首先定义了结构体 `struct k`,然后使用 `qsort` 函数按照 `d` 的大小从大到小对结构体数组进行排序,最后输出排序后的结果。希望可以帮助到你!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-12-15 16:54:31 | 显示全部楼层
FishC 发表于 2023-12-15 16:38
非常抱歉理解错误。如果要按照结构体数组中的 d 值从大到小输出整个数组,可以使用标准库函数 `qsort` 来 ...

这串代码 无法在dev-c++里面运行 有什么解决办法吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-12-15 16:54:55 | 显示全部楼层
-kasha 发表于 2023-12-15 16:54
这串代码 无法在dev-c++里面运行 有什么解决办法吗

如果在 Dev-C++ 中无法运行该代码,可能是由于 Dev-C++ 不支持 C99 标准库函数 `qsort` 导致的。为了解决这个问题,你可以使用传统的冒泡排序算法来手动实现按照 "d" 的大小从大到小排序的功能。下面是经过修改的示例代码:#include #include struct k{    int a;    int b;    int c;    int d;};int main() {    struct k pep[] = {        {2,3,5,4},        {4,5,7,8},        {1,2,3,4},        {7,8,9,10},        {3,2,1,0},        {0,7,4,1},        {2,2,2,2},        {6,6,6,6},        {8,8,8,8},        {10,10,10,10}    };    int n = sizeof(pep) / sizeof(struct k);  // 计算结构体数组的长度    // 使用冒泡排序按照 d 的大小进行排序    for (int i = 0; i < n-1; i++) {        for (int j = 0; j < n-1-i; j++) {            if (pep[j].d < pep[j+1].d) {                // 交换两个结构体的位置                struct k temp = pep[j];                pep[j] = pep[j+1];                pep[j+1] = temp;            }        }    }    // 输出排序后的结果    for (int i = 0; i < n; i++) {        printf("a = %d, b = %d, c = %d, d = %d\n", pep.a, pep.b, pep.c, pep.d);    }    return 0;}这段代码使用冒泡排序算法实现了按照 "d" 的大小从大到小对结构体数组进行排序,并输出排序后的结果。希望这次能够在 Dev-C++ 中成功运行!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-6-3 06:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表