数据结构字节对齐

server/2024/9/23 5:57:51/
  1. 求 sizeof(name1)?(晟安信息)

struct name1{

    char str;

    short x;

    int num;

};

8

分析:char 1字节,short 2字节,int 4字节;所以以4字节为一个步长,需要2步长,所以sizeof(name1)为8。

  1. (电工时代)

typedef struct _a

{

    char c1;

    long i;

    char c2;

    double f;

}a;

typedef struct _b

{

    char c1;

    char c2;

    long i;

    double f;

}b;

sizeof(a) = _______;

sizeof(b) = _______;

32        24

分析 :char 1字节,long 8字节,double 8字节;所以以8字节为一个步长,c语句按顺序执行,sizeof(a)需要4步长,所以sizeof(a)为32;sizeof(b)需要3步长,所以sizeof(b)为24。

  1. 给了一个结构体,求 sizeof(struct A) = ________。 (鲁科安全,软通动力)

struct A{

    char a;

    char b;

    char c;

    short d;

    int e;

    short f;

}

16

分析:char 1字节,short 2字节,int 4字节;所以以4字节为一个步长,需要4步长,所以sizeof(struct A)为16。

  1. 有一个如下的结构体,请问在64位编译器下用 sizeof(struct A) 计算出的大小是多少?( ) (鲁科安全)

struct A{

    long a1;

    short a2;

    int a3;

    int *a4;

}

A. 24 B. 28 C. 16 D. 18

A

分析:long 8字节,short 2字节,int 4字节,指针 8字节;所以以8字节为一个步长,需要3步长,所以sizeof(struct A)为24。

  1. 有以下说明语句,则下列错误的引用 是( )。(山大华天)

struct stu

{

    int no;

    char name[21];

};

stu w, *p = &w;

A. w.no B*p.no C. p->no D. (*p).no

B

分析:*p.no 错误,*p是正确解引用指针p的方式,但.*操作符不能这样分开使用。正确的写法应为(*p).no。

  1. 写出下述程序结果: (中维世纪)

typedef struct test

{

    char x1;

    short x2;

    float x3;

    char x4;

}TEST_T;

printf("%d", sizeof(TEST_T));

12

分析:char 1字节,short 2字节,float 4字节;所以以4字节为一个步长,需要3步长,所以sizeof(TEST_T)为12。

  1. 下面的代码输出是什么,为什么?(64位环境) (信雅达)

struct {

    char *a1;

    long a2;

    short a3;

}A;

int main(void)

{

    printf("%d", sizeof(A));

}

24

分析:指针 8字节,short 2字节,long 8字节;所以以8字节为一个步长,需要3步长,所以sizeof(A)为24。

  1. 设有如下结构定义: struct student { int num; char name[20]; char sex; int age; char addr[30];} stud; 若用printf("%s\n", .....)访问该结构中name值的正确方法是 ( ) (杭州快越科技)

A. stud -> name B. &stud.name

C. stud.&name D. stud.name

D

  1. struct

{

short a; char b; float c;

}cs;

则sizeof(cs)的值是( ) (苏州特点电子科技)

A.4 B.5 C.7 D.8

D

分析:char 1字节,short 2字节,float 4字节;所以以4字节为一个步长,需要2步长,所以sizeof(cs)为8。

  1. 如下函数的输出结果是:【 】

struct node

{

char a; short b; char c; int d;

};

struct node s = { 3, 5, 6, 99 };

struct node *pt = &s;

printf("%X\n", *(int*)pt);

5003

  1. 编程题:定义学生结构体,存储学生的学号、姓名、分数,定义长度为5的结构体数组,实现:

①输入学生信息

②输出学生信息

③计算学生的成绩总分、平均分

④按照学生的分数进行排序

⑤输出排序后的数组

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define N 5
//创建学生结构体,并重命名
typedef struct Students{int id;char name[20];float score;
}Stu[N];//输入学生信息
void Stu_input(Stu arr);//输出学生信息
void Stu_output(Stu arr);//求总分和平均分
void Stu_MAX_AVG(Stu arr); //排名
void Stu_sord(Stu arr);int main(int argc, const char *argv[])
{//定义数组arr,初始化Stu arr={0};//输入学生信息Stu_input(arr);printf("\n");//输出学生信息Stu_output(arr);	printf("\n");//求总分和平均分Stu_MAX_AVG(arr);printf("\n");//排名Stu_sord(arr);//输出排名后的数组Stu_output(arr);return 0;
}//输入学生信息
void Stu_input(Stu arr){for(int i=0; i<N; i++){printf("请输入第%d个学生信息:", i+1);scanf("%d%s%f", &arr[i].id, arr[i].name, &arr[i].score);}
}//输出学生信息
void Stu_output(Stu arr){for(int i=0; i<N; i++){printf("学号%d 姓名%5s 分数%.2f\n", arr[i].id, arr[i].name, arr[i].score);}
}//求总分和平均分
void Stu_MAX_AVG(Stu arr){float sum = 0;for(int i=0; i<N; i++){sum += arr[i].score; }printf("总分是:%.2f 平均分是:%.2f\n", sum, sum/N);
}//排名
void Stu_sord(Stu arr){for(int i=1; i<N; i++){for(int j=0; j<N-i; j++){if( arr[j].score < arr[j+1].score ){Stu s = {0};s[j] = arr[j];arr[j] = arr[j+1];arr[j+1] = s[j];}}}
}

结果如下:


http://www.ppmy.cn/server/120663.html

相关文章

C++学习笔记(36)

300、Linux 的 Hello world 一、快速入门 Linux 用两天的时间学习《程序员两天快速入门 Linux》。 二、安装软件包 1&#xff09;安装 C 和 C的编译器 yum -y install gcc* 2&#xff09;升级编译器 升级软件包&#xff1a; yum -y install centos-release-scl devtoolset-8-gc…

基于YOLOv5的教室人数检测统计系统

基于YOLOv5的教室人数检测统计系统可以有效地用于监控教室内的学生数量&#xff0c;适用于多种应用场景&#xff0c;比如 自动考勤、安全监控或空间利用分析 以下是如何构建这样一个系统的概述&#xff0c;包括环境准备、数据集创建、模型训练以及如何处理不同类型的媒体输入…

C语言 | Leetcode C语言题解之第424题替换后的最长重复字符

题目&#xff1a; 题解&#xff1a; int characterReplacement(char* s, int k) {int num[26];memset(num, 0, sizeof(num));int n strlen(s);int maxn 0;int left 0, right 0;while (right < n) {num[s[right] - A];maxn fmax(maxn, num[s[right] - A]);if (right - …

五、CAN总线

目录 一、基础知识 1、can介绍 2、CAN硬件电路 3、CAN电平标准 4、CAN收发器芯片介绍 5、CAN帧格式 ① CAN帧种类 ② CAN数据帧 ③ CAN遥控帧​编辑 ④ 位填充 ⑤ 波形实例 6、接收方数据采样 ① 接收方数据采样遇到的问题 ② 位时序 ③ 硬同步 ④ 再同步 ⑤ 波…

换个手机IP地址是不是不一样?

在当今这个信息爆炸的时代&#xff0c;手机已经成为我们生活中不可或缺的一部分。而IP地址&#xff0c;作为手机连接网络的桥梁&#xff0c;也时常引起我们的关注。你是否曾经好奇&#xff0c;换个手机&#xff0c;IP地址会不会也跟着变呢&#xff1f;本文将深入探讨这个问题&a…

Neo4j 简单使用

在 Neo4j 项目中&#xff0c;搭建和使用主要包括以下几个步骤&#xff1a; 1. 安装 Neo4j 首先&#xff0c;安装 Neo4j 可以选择多种方式&#xff0c;包括&#xff1a; 本地安装&#xff1a;在 Windows、macOS 或 Linux 系统中&#xff0c;通过官网下载对应的 Neo4j 安装包。…

【论文阅读】Benchmarking Retrieval-Augmented Generation for Medicine

论文&#xff1a;https://arxiv.org/abs/2402.13178 代码&#xff1a; GitHub - Teddy-XiongGZ/MIRAGE: Official repository of the MIRAGE benchmark GitHub - Teddy-XiongGZ/MedRAG: Code for the MedRAG toolkit 研究背景&#xff1a; 系统地评估医用rag QA系统&#xff0…

【LLM论文日更】| 俄罗斯套娃嵌入模型

论文&#xff1a;https://proceedings.neurips.cc/paper_files/paper/2022/file/c32319f4868da7613d78af9993100e42-Paper-Conference.pdf代码&#xff1a;GitHub - RAIVNLab/MRL: Code repository for the paper - "Matryoshka Representation Learning"机构&#x…