C语言--结构体变量和数组的定义、初始化、赋值

1.求 sizeof(name1)?

struct name1{

char str;

short x;

int num;

};

答:8
分析:结构体分配内存时采用字节对齐原则,先看最大字节,int占4字节,为了避免跨步存储,结构体内存步长为4,char占1字节,short占2字节,两者相加未超过步长,可以存储在一起,所以一共开辟8字节空间;

2.

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) = 32___;

sizeof(b) = 24_;

分析:按照字节对齐原则,先看最大字节为double 8字节,所以步长为8,为char分配8字节,long占8字节因此需要再开辟8字节内存,然后为char变量分配8字节,最后为double分配8字节,共4*8=32字节;

第二函数由于char类型变量可以一起存储在8字节内,所以共3*8=24字节;

3.给了一个结构体,求 sizeof(struct A) = 16__。

struct A{

char a;

char b;

char c;

short d;

int e;

short f;

}

分析:最大字节为int:4字节,所以步长为4,char类型只占1字节,因此变量a、b、c可以存储在一个步长内,short占2字节,此时第一个步长内存不够,需要再开辟4字节,然后为int开辟4字节,最后是short的4字节,共:4*4=16字节;

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

struct A{

long a1;

short a2;

int a3;

int *a4;

}

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

5.有以下说明语句,则下列错误的引用是(B )。

struct stu

{

int no;

char name[21];

};

stu w, *p = &w;

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

分析:调用结构体变量格式是结构体名.成员变量,而调用结构体指针是结构体指针->成员变量;或者是先对p解值然后调用结构体变量;

6.写出下述程序结果:

typedef struct test

{

char x1;

short x2;

float x3;

char x4;

}TEST_T;

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

答:12
分析:最大字节为float:4字节,步长为4,char和short可以存储在一个步长内,所以只需要开辟1个4字节,共3*4=12字节;

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

struct {

char *a1;

long a2;

short a3;

}A;

int main(void)

{

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

}

答:24;因为最大字节数为8,三个变量都独占一个步长,共3*8=24字节;

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

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

C. stud.&name D. stud.name

分析:结构体变量可以通过点操作符(.)来访问其成员。

9.

struct

{

short a; char b; float c;

}cs;

则sizeof(cs)的值是(D )

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

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

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);

答:若是小端存储,输出结果为0x50003;若是大段存储,输出结果为0x30005
分析:

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

①输入学生信息

②输出学生信息

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

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

⑤输出排序后的数组

代码如下:

cpp 复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
//定义一个学生结构体并重名为Stu
typedef struct student{
	int id;
	char name[20];
	float score;
}Stu,*Stu_ptr,Stu_Arr[5];
int main(int argc, const char *argv[])
{
	//学生结构体 指针变量p
	Stu_Arr arr;
	for(int i=0;i<5;i++){
		printf("请输入第%d个学生信息:",i+1);
		scanf("%d %s %f",&arr[i].id,arr[i].name,&arr[i].score);
	}
	float sum=0.0,avg=0.0;
	for(int i=0;i<5;i++){
		sum+=arr[i].score;
		printf("%d %s %.2f\n",arr[i].id,arr[i].name,arr[i].score);
	}
	avg=sum/5;
	printf("五名学生的总分为%.2f 平均分为%.2f\n",sum,avg);
	for(int i=1;i<5;i++){
		for(int j=0;j<5-i;j++){
			if(arr[j].score>arr[j+1].score){
				float t=arr[j].score;
				arr[j].score=arr[j+1].score;
				arr[j+1].score=t;
			}
		}
	}
	printf("按成绩排名后学生信息:\n");
	for(int i=0;i<5;i++){
		printf("%d %s %.2f\n",arr[i].id,arr[i].name,arr[i].score);
	}
	return 0;
}

运行结果如图所示:

相关推荐
元气代码鼠2 分钟前
学习C++:数组
开发语言·c++
第二层皮-合肥7 分钟前
matlab系列专栏-matlab概述
开发语言·matlab
XWXnb67 分钟前
数据结构:循环单链表
数据结构
arin87613 分钟前
【数据结构】树链刨分
数据结构·算法
sjsjs1114 分钟前
【数据结构-单调队列】力扣1438. 绝对差不超过限制的最长连续子数组
数据结构·算法·leetcode
2401_8582861115 分钟前
122.【C语言】数据结构之快速排序(Hoare排序的优化)
c语言·开发语言·数据结构·算法·排序算法
奔跑de自由16 分钟前
C语言指针-冒泡排序之旅
c语言·算法·排序算法
猫猫的小茶馆33 分钟前
【数据结构】栈与队列(FIFO)
linux·c语言·数据结构·算法·链表
CN.LG33 分钟前
C# 实现串口通信
开发语言·c#
Bony-1 小时前
Go语言中值接收者和指针接收者的区别?
开发语言·后端·golang