有依次对应关系的数组X、Y、Z,如何排序其中一个X数组,使得另外的数组还与排序完成后的数组相对应(C语言实现)

1. 目的

有依次对应关系的数组X、Y、Z,排序其中一个X数组,使得另外的数组还与排序完成后的数组相对应,并打印出排序完成后的X、Y、Z数组。

2. 具体实现

以下面的这个对应关系为例,进行相应编程实现。

c 复制代码
X = [3.7,7.7,-6.6,1.5,-4.5,7.0,3.2,-0.7,9.0,-2.2];
Y = [-1.2,5.1,9.7,3.6,-6.6,7.6,-3.0,10.0,-4.1,0.1];
Z = [10.2,8.0,4.8,17.6,5.6,0.2,14.8,6.2,3.7,11.9];

要对其中数组进行排序并保持它们之间的一一对应关系,可以使用结构体数组来实现。对于排序,这里使用简单的冒泡排序(其他排序都可以)来实现,具体代码如下:

c 复制代码
#include <stdio.h>
// 定义结构体
typedef struct {
    float x;
    float y;
    float z;
} Point;

//简单的冒泡排序
void bubbleSort(Point arr[], int n) {
    for (int i = 0; i < n-1; i++) {
        for (int j = 0; j < n-i-1; j++) {
            if (arr[j].x > arr[j+1].x) {
                // 交换结构体元素
                Point temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
}
int main() {
    // 假设有三个数组
    float  X[10] = {3.7,7.7,-6.6,1.5,-4.5,7.0,3.2,-0.7,9.0,-2.2};
    float  Y[10] = {-1.2,5.1,9.7,3.6,-6.6,7.6,-3.0,10.0,-4.1,0.1};
    float  Z[10] = {10.2,8.0,4.8,17.6,5.6,0.2,14.8,6.2,3.7,11.9};
    // 创建结构体数组并初始化
    Point points[10];
    for (int i = 0; i < 10; i++) {
        points[i].x = X[i];
        points[i].y = Y[i];
        points[i].z = Z[i];
    }
    // 对结构体数组进行排序
    bubbleSort(points, 10);
    // 打印排序后的X数组结果
    printf(" X = [");
    for (int i = 0; i < 10; i++) {
        printf("%.1f", points[i].x);
		if (i < 9) {
            printf(", ");
        }
    }
	 printf("];\n");
  // 打印排序后的Y数组结果
	 printf(" Y = [");
    for (int i = 0; i < 10; i++) {
        printf("%.1f", points[i].y);
		if (i < 9) {
            printf(", ");
        }
    }
	 printf("];\n");
  // 打印排序后的Z数组结果
	 printf(" Z = [");
    for (int i = 0; i < 10; i++) {
        printf("%.1f", points[i].z);
		if (i < 9) {
            printf(", ");
        }
    }
	 printf("];\n");
    return 0;
}

运行结果如下:

相关推荐
水饺编程27 分钟前
第5章,[标签 Win32] :GDI 的基本图形
c语言·c++·windows·visual studio
水饺编程29 分钟前
第5章,[标签 Win32] :GDI 的其他方面的分类
c语言·c++·windows·visual studio
计算机安禾30 分钟前
【数据结构与算法】第46篇:算法思想(一):递归与分治
c语言·数据结构·c++·算法·visualstudio·图论·visual studio code
Sirens.31 分钟前
七大经典排序算法:原理、实现与复杂度分析
java·数据结构·算法·排序算法
Shadow(⊙o⊙)41 分钟前
C中 memset enum malloc fputc fgetc fgets fread fwrite rewind指针回退
java·c语言·数据库
wengqidaifeng43 分钟前
第十七届蓝桥杯C/C++软件赛C组算法题讲解
c语言·c++·蓝桥杯
Shadow(⊙o⊙)1 小时前
C学习历程的总汇
c语言·学习·jquery
艾莉丝努力练剑1 小时前
【Linux线程】Linux系统多线程(五):<线程同步与互斥>线程互斥
linux·运维·服务器·c语言·c++·学习·ubuntu
我不是懒洋洋1 小时前
【经典题目】链表OJ(轮转数组、返回倒数第k个节点、链表的回文结构)
c语言·开发语言·数据结构·算法·链表·visual studio
励志的小陈1 小时前
数据结构--堆(C语言实现)
android·c语言·数据结构