Files
suanfa/public/c/ch4/bestload/loading.c
T

48 lines
1.6 KiB
C
Raw Normal View History

2026-06-14 23:45:55 +08:00
#include <stdio.h>
#include <stdlib.h>
typedef struct { float weight; int index;} Element;
int compare(const void *a, const void *b) {
const Element *elemA = (const Element *)a;
const Element *elemB = (const Element *)b;
return (elemA->weight > elemB->weight) - (elemA->weight < elemB->weight);
}
// 最优装载函数
float loading(float capacity, float weights[], int count, int x[]) {
Element *elements = malloc(count * sizeof(Element));
for (int i = 0; i < count; i++) { // 初始化元素
elements[i].weight = weights[i];
elements[i].index = i;
}
qsort(elements, count, sizeof(Element), compare); // 排序元素
// 初始化装载情况
for (int i = 0; i < count; i++) { x[i] = 0; }
float totalWeight = 0;
// 贪心选择
for (int i = 0; i < count && elements[i].weight <= capacity; i++) {
totalWeight += elements[i].weight;
capacity -= elements[i].weight;
x[elements[i].index] = 1; // 标记被装载的集装箱
}
free(elements); // 释放动态分配的内存
return totalWeight;
}
int main() {
float weights[] = {20, 30, 26, 15, 30, 40, 35,50,25};
float capacity = 100;
int count = sizeof(weights) / sizeof(weights[0]);
int *x = malloc(count * sizeof(int));
float optimalWeight = loading(capacity, weights, count, x);
printf("最优得到装载重量为:%.2f\n", optimalWeight);
printf("被装载的集装箱序号为(下标从0开始)");
for (int i = 0; i < count; i++) {
if (x[i] == 1) {
printf("%d ", i);
}
}
free(x); // 释放动态分配的内存
return 0;
}