从零开始学习嵌入式----结构体struct和union习题回顾

一、 通过结构体和自定义函数实现成绩从大到小的排序,要求在主函数内定义结构体数组。

cs 复制代码
#include <stdio.h>
//定义一个结构体类型
typedef struct Student
{
    int age;
    char name[32];
    float score;
} STU;
//定义一个函数实现成绩从小到大的排序
void fun(STU *p, int num)
{
    //通过冒泡排序实现成绩从大到小的排序
    for (int i = 0; i < num - 1; i++)
    {
        for (int j = 0; j < num - 1 - i; j++)
        {
            if (p[j].score > p[j + 1].score)
            {
                STU t = p[j];//定义一个临时结构体变量实现参数的交换
                p[j] = p[j + 1];
                p[j + 1] = t;
            }
        }
    }
}
int main(int argc, char const *argv[])
{
    //在主函数内定义结构体数组
    STU stu[3] = {{1, "zhang", 23.5}, {2, "wang", 45.7}, {76, "li", 87.6}};
    STU *sp = stu;//定义一个结构体指针
    fun(sp, 3);//从小到大排序
    //打印输出数据
    for (int i = 0; i < 3; i++)
    {
        printf("%d %s %.2f\n", stu[i].age, stu[i].name, stu[i].score);
    }
    return 0;
}

二、 通过union联合体判断计算机是大端存储还是小端存储。

cs 复制代码
#include <stdio.h>
union demo
{
  int a;
  char b;
};

int main(int argc, char const *argv[])
{
  union demo d1;
  d1.a=0x12345678;
  printf("%#x\n",d1.b);//0x78
  return 0;
}
相关推荐
HelloRevit1 分钟前
React DndKit 实现类似slack 类别、频道拖动调整位置功能
前端·javascript·react.js
evolution_language6 分钟前
LintCode第974题-求矩阵各节点的最短路径(以0为标准)
算法·最短路径·广度优先搜索
序属秋秋秋12 分钟前
算法基础_基础算法【位运算 + 离散化 + 区间合并】
c语言·c++·学习·算法·蓝桥杯
Phoebe鑫18 分钟前
数据结构每日一题day10(链表)★★★★★
算法
jyyyx的算法博客24 分钟前
【再探图论】深入理解图论经典算法
c++·算法·图论
念_ovo32 分钟前
【算法/c++】利用中序遍历和后序遍历建二叉树
数据结构·c++·算法
梭七y34 分钟前
【力扣hot100题】(048)二叉树的最近公共祖先
算法·leetcode·职场和发展
luckyme_38 分钟前
leetcode-代码随想录-链表-移除链表元素
算法·leetcode·链表
Vitalia39 分钟前
⭐算法OJ⭐寻找最短超串【动态规划 + 状态压缩】(C++ 实现)Find the Shortest Superstring
开发语言·c++·算法·动态规划·动态压缩
ohMyGod_12341 分钟前
用React实现一个秒杀倒计时组件
前端·javascript·react.js