为了账号安全,请及时绑定邮箱和手机立即绑定

作业社区

探索学习新天地,共享知识资源!

0 提交作业
0 布置作业
0 满分作业
得分 100
讨论题

慕尼黑0001808 的学生作业:

/* 练习 struct student { int id; short score; char name[5]; }; //计算出上述类型的大小,并打印输出 */ #include #define MAX_ALIGNMENT 4 size_t offset = 0; /** * @brief 添加结构体成员并计算对齐后的偏移量 * * @param size 当前成员的大小(单位:字节) * @param alignment 当前成员的对齐要求(例如:int 为 4,short 为 2) * * 功能说明: * 1. 根据成员的对齐要求计算填充字节(padding)。 * 2. 更新全局偏移量 offset = 原偏移 + 填充字节 + 成员大小。 * 3. 打印填充和成员占用的字节数(调试用)。 */ void add_member(size_t size, size_t alignment) { // 计算需要的填充字节数: // 如果当前偏移量(offset)不是 alignment 的倍数, // 则需要补齐到最近的 alignment 的倍数。 // 例如:offset=5, alignment=4 → padding=3 (因为 5+3=8 是4的倍数) size_t padding = 0; if (offset % alignment != 0) { padding = alignment - (offset % alignment); } // 更新全局偏移量: // 新偏移量 = 原偏移 + 填充字节 + 成员大小 offset += padding + size; printf("+%zu (padding) +%zu (member) → offset = %zu\n", padding, size, offset); } size_t finalize_struct_size() { if (offset % MAX_ALIGNMENT != 0) { size_t padding = MAX_ALIGNMENT - (offset % MAX_ALIGNMENT); offset += padding; printf("+%zu (final padding) → total size = %zu\n", padding, offset); } return offset; } int main() { offset = 0; printf("Calculating size of struct student:\n"); add_member(4, 4); // int id add_member(2, 2); // short score add_member(5, 1); // char name[5] size_t total_size = finalize_struct_size(); printf("Final struct size: %zu bytes\n", total_size); return 0; }

得分 100
学习任务

Hee_cryLQ0 的学生作业:

seqlist.h #ifndef __SEQLIST__ #define __SEQLIST__ #include #include #include #define MAX 5 typedef struct student { char name[20]; int id; int age; }datatype_t; typedef struct { datatype_t buf[MAX]; //buf[10]:顺序表中有10个学生 int n; }seqlist_t; seqlist_t *create_empty_seqlist(); int is_full_seqlist(seqlist_t *list); void insert_data_seqlist(seqlist_t *list, datatype_t data); void printf_data_seqlist(seqlist_t *list); int is_empty_seqlist(seqlist_t *list); int delete_data_seqlist(seqlist_t *list,datatype_t data); #endif //__SEQLIST__ seqlist.c #include "seqlist.h" /*创建一个空的顺序表*/ seqlist_t *create_empty_seqlist() { seqlist_t *list = NULL; //list本身是局部变量 list = (seqlist_t *)malloc(sizeof(seqlist_t));//而list保存的地址在堆区 if(NULL == list) { printf("malloc seqlist failed!\n"); return NULL; } memset(list, 0, sizeof(seqlist_t)); list->n = 0; return list; } /*检查顺序表是否已经存满数据MAX=10*/ int is_full_seqlist(seqlist_t *list) { return list->n == MAX ? 1 : 0; } /*向顺序表中插入学生信息,传入学生对象data*/ void insert_data_seqlist(seqlist_t *list, datatype_t data) { strcpy(list->buf[list->n].name, data.name);//数组名是数组首地址,不能对数组名进行=赋值,所以需要使用strcpy list->buf[list->n].id = data.id; list->buf[list->n].age = data.age; list->n = list->n + 1; //list->n++; return ; } /*打印顺序表中的学生信息*/ void printf_data_seqlist(seqlist_t *list) { printf("name\tid\tage\n"); for(int i = 0; i < list->n; i++) { printf("%s\t%d\t%d\n",list->buf[i].name, list->buf[i].id, list->buf[i].age); } return ; } int is_empty_seqlist(seqlist_t *list) { return list->n == 0 ? 1 : 0; } int delete_data_seqlist(seqlist_t *list ,datatype_t data) { int i = 0, j = 0; if(is_empty_seqlist(list)) { printf("seqlist is empty!\n"); return -1; } //删除指定id的学生信息 for(i = 0; i < list->n; i++) { if(list->buf[i].id != data.id) { list->buf[j] = list->buf[i];//把没有被删除的学生信息赋值给buf[j],则buf[j]为删除后的表的元素,j为新的表的大小 j++; } } //更新顺序表大小 list->n = j; //判断删除数据是否存在 if(i == j) //执行上面程序后i依然等于j,说明没有元素被删除 { printf("要删除的数据不存在\n"); return -2; } else { printf("被删除的学生ID为:%d\n", data.id); } return 0; } main.c #include "seqlist.h" int main() { seqlist_t *list = NULL; list = create_empty_seqlist();//创建一个空表 datatype_t data; //创建学生对象 printf("请输入学生的信息,最多输入%d个。\n", MAX); while(!is_full_seqlist(list)) { scanf("%s%d%d", data.name, &data.id, &data.age); insert_data_seqlist(list, data); } printf_data_seqlist(list); printf("请输入要删除的学生id :\n"); scanf("%d",&data.id); int ret = delete_data_seqlist(list, data); if(ret < 0) { printf("要删除的顺序表为空,或要删除的信息不存在\n"); return -1; } printf_data_seqlist(list); free(list); list = NULL; return 0; }

微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号