C++第2周项目1——有序的结构体数组

该博客展示了一段C++代码,用于对包含学生成绩的结构体数组进行排序。首先按C++成绩降序排序,然后按学号升序排序,并输出排序后的结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称:score.cpp
* 作    者:
* 完成日期: 2013 年 4 月 13  日
* 版本号: v1.0
* 输入描述:已经在程序中初始化
* 问题描述:将学生成绩信息存储在结构体数组中,对结构体排序并输出
* 输出:按C++降序和按学号升序排序后的学生成绩单
*/

#include <iostream>
#include <cstring>
using namespace std;
struct Score
{
    char num[14];
    int cpp;
    int math;
    int english;
};
void sort1(Score array[],int n)
{
    int i,j;
    Score temp;
    for(i=1;i<n;i++)
    {
        for(j=0;j<n-i;j++)
        {
            if(array[j].cpp<array[j+1].cpp)
            {
                temp=array[j];
                array[j]=array[j+1];
                array[j+1]=temp;
            }
        }

    }
}
void sort2(Score array[],int n)
{
    int i,j;
    Score temp;
    for(i=1;i<n;i++)
    {
        for(j=0;j<n-i;j++)
        {
            if(strcmp(array[j].num,array[j+1].num)>0)      //用string,别忘了 包含  cstring。。
            {
                temp=array[j];
                array[j]=array[j+1];
                array[j+1]=temp;
            }
        }

    }
}
void output(Score array[],int n)
{
    int i;
    for(i=0;i<n;i++)
    {
        cout<<array[i].num<<"  "<<array[i].cpp<<"  "<<array[i].math<<"  "<<array[i].english<<endl;
    }
}

int main()
{
    Score score[]={{"201152501104",65,69 ,68 },
    {"201152501114",94 ,89 ,63 },
    {"201152501138",67 ,62 ,84 },
    {"201152501204",100 ,65 ,91 },
    {"201152501202",59 ,80 ,55 },
    {"201152501115",92 ,84 ,60 },
    {"201152501201",80 ,92 ,71 },
    {"201152501145",88 ,56 ,67 },
    {"201152501203",62 ,62 ,95 },
    {"201152501140",80 ,60 ,86 },
    {"201152501205",73 ,90 ,94}};
    int stuNum=sizeof(score)/sizeof(score[0]);
    //将所有同学按C++降序排序后输出
    sort1(score,stuNum);
    cout<<"按C++降序排序后:"<<endl;
    output(score,stuNum);
    //将所有同学按学号升序排序后输出
    sort2(score,stuNum);
    cout<<"按学号升序排序后:"<<endl;
    output(score,stuNum);
    return 0;
}

### C++ 中声明结构体数组的方法 在 C++ 编程语言中,可以通过定义一个结构体类型来存储多个相关变量的数据集合。为了处理一组具有相同类型的结构体实例,可以使用 **结构体数组** 的形式。 #### 结构体数组的声明方法 结构体数组的声明类似于普通数组的声明方式,只需指定结构体名称以及所需的数组大小即可。以下是具体的语法: ```cpp struct StructName { 数据类型 成员名1; 数据类型 成员名2; }; StructName arrayName[arraySize]; ``` 其中 `StructName` 是已定义的结构体类型,`arrayName` 表示数组的名字,而 `arraySize` 则是数组的长度[^2]。 #### 示例代码 下面是一个完整的例子,展示如何声明和初始化一个结构体数组,并对其进行操作: ```cpp #include <iostream> using namespace std; // 定义结构体 struct Person { char name[20]; // 名字 int age; // 年龄 }; int main() { // 声明一个包含5个Person结构体数组 struct Person people[5]; // 初始化第一个元素 strcpy(people[0].name, "Alice"); people[0].age = 25; // 初始化第二个元素 strcpy(people[1].name, "Bob"); people[1].age = 30; // 输出数组中的数据 cout << "First person's name: " << people[0].name << ", Age: " << people[0].age << endl; cout << "Second person's name: " << people[1].name << ", Age: " << people[1].age << endl; return 0; } ``` 上述代码展示了如何定义一个名为 `Person` 的结构体,并创建了一个包含五个 `Person` 类型成员的数组 `people`。接着分别对前两个成员进行了赋值操作,并通过标准输出流将其显示出来。 #### 使用指针访问结构体数组 除了传统的数组索引外,还可以借助指针的方式访问结构体数组的内容。这种方式对于某些特定场景可能更加高效或者灵活。例如,在遍历整个数组时可以直接移动指向当前项的指针而不是改变下标[^3]。 ```cpp for (struct Person *p = &people[0]; p < &people[5]; ++p) { cout << (*p).name << ": " << (*p).age << "\n"; } ``` 以上片段说明了另一种循环读取所有记录的技术——运用指针算术运算完成迭代过程。 ### 总结 综上所述,C++ 提供了一种简单有效的方式来管理和操作大量同质化的复杂数据单元即结构体数组。这不仅限于基本的例子如人员名单管理,也可以扩展到更复杂的实际应用场合比如图书管理系统的设计与开发当中去[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值