C语言之结构体(二)

  1. 结构体对齐补齐
  2. 位段
c 复制代码
// 
// 结构体对齐补齐
// 结构体的大小一定是4的倍数。
// 如果成员变量大小加起来不足4的倍数 补齐。
// 为什么这样,是因为有对齐原则
// 如果是比较大的成员  首地址必须是4的倍数
// 如果是比较小的成员  可以几个凑成4.
//
struct A {
	char c;
	int i;
	double d;
};
void test8()
{
	struct A a;
	printf("%d", sizeof(a));
}

// 位段
// 有时候用不到特别大的内存 ,可以用位段来节约内存
// 例如:需要32个bit位  用结构体最少是32个字节
//
void test9()
{
	struct f {
		unsigned bit1 : 1;
		unsigned bit2 : 2;
		unsigned bit3 : 3;
	};
	struct f f1 = { 9,9,9 };
	printf("%d,%d,%d\n", f1.bit1, f1.bit2, f1.bit3);
	printf("\n%d\n", sizeof(f1));
}
  1. 案例
c 复制代码
void test10()
{
	typedef struct Student
	{
		char name[20];
		int age;
		double score;
	} Student;
	int n;
	printf("请输入学生数:");
	scanf("%d", &n);
	Student* p = malloc(sizeof(Student) * n);
	if (NULL == p)
	{
		printf("申请内存失败\n");
		return -1;
	}
	double count = 0;
	for (int i = 0; i < n; i++)
	{
		printf("请输入第%d个同学的姓名:", i + 1);
		scanf("%s", (p + i)->name);
		printf("请输入第%d个同学的年龄:", i + 1);
		scanf("%d", &(p + i)->age);
		printf("请输入第%d个同学的成绩:", i + 1);
		scanf("%lf", &(p + i)->score);
		count += (p + i)->score;
	}
	printf("总分:%g,平均分:%g\n", count, count / n);

}
相关推荐
xxxxxxllllllshi20 分钟前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L23 分钟前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先
铁手飞鹰29 分钟前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
专业抄代码选手2 小时前
【Leetcode】1930. 长度为 3 的不同回文子序列
javascript·算法·面试
[J] 一坚2 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法
czlczl200209252 小时前
算法:二叉搜索树的最近公共祖先
算法
司铭鸿2 小时前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
yk0820..3 小时前
测试用例的八大核心要素
数据结构
SoleMotive.3 小时前
redis实现漏桶算法--https://blog.csdn.net/m0_74908430/article/details/155076710
redis·算法·junit
-森屿安年-4 小时前
LeetCode 283. 移动零
开发语言·c++·算法·leetcode