如何设计一个合适的恒星结构体类型来存储N个恒星的名称(字符串)和三维坐标(整数或浮点数),并将它们存入结构体数组?同时,该结构体应该能实现找到距离地球最近和最远的恒星名称。假设每个恒星都有唯一的距离与地球的距离值,且数组中只包含一个最近和一个最远的恒星。
时间: 2024-12-25 22:25:14 浏览: 10
为了设计一个合适的恒星结构体类型,我们可以创建一个名为`Star`的结构体,它包含两个部分:恒星的基本信息(名称和坐标)以及与地球的距离。这里可以将坐标表示为浮点数,因为星系位置通常用弧度或光年表示,不是整数。
```c
#include <stdio.h>
#include <string.h>
#include <math.h>
typedef struct {
char name[50]; // 恒星名称,最大长度为49字符加上终止符'\0'
float x, y, z; // 三维坐标,浮点数表示
float distance_to_earth; // 从地球到此恒星的距离,浮点数
} Star;
// 初始化结构体数组
Star stars[N]; // N是恒星的数量
// 函数来设置恒星的属性
void set_star_info(Star* star, const char* name, float x, float y, float z, float distance) {
strncpy(star->name, name, sizeof(star->name) - 1);
star->x = x;
star->y = y;
star->z = z;
star->distance_to_earth = distance;
}
// 找到距离地球最近和最远的恒星
int find_nearest_and_farthest() {
int nearest_index = 0, farthest_index = 0;
float min_distance = stars[0].distance_to_earth, max_distance = stars[0].distance_to_earth;
for (int i = 1; i < N; i++) {
if (stars[i].distance_to_earth < min_distance) {
min_distance = stars[i].distance_to_earth;
nearest_index = i;
}
if (stars[i].distance_to_earth > max_distance) {
max_distance = stars[i].distance_to_earth;
farthest_index = i;
}
}
return nearest_index, farthest_index;
}
// 主函数演示如何使用
int main() {
for (int i = 0; i < N; i++) {
set_star_info(&stars[i], "恒星" + std::to_string(i), /*星座坐标*/ ... , /*距离地球距离*/ ...);
}
int nearest_star_index, farthest_star_index;
nearest_star_index = farthest_star_index = find_nearest_and_farthest();
printf("最近的恒星是:%s,距离地球 %.2f\n", stars[nearest_star_index].name, stars[nearest_star_index].distance_to_earth);
printf("最远的恒星是:%s,距离地球 %.2f\n", stars[farthest_star_index].name, stars[farthest_star_index].distance_to_earth);
return 0;
}
```
阅读全文