线性表的链式表示和实现(malloc函数和struct结构体指针)

一、malloc函数

malloc函数

(void *)malloc(int size)

功能:动态分配指定大小的内存空间
输入:指定大小的内存空间(参数大小:字节)
返回类型为:void*,如果分配内存失败,返回的值为NULL(0);
用法

char *pCh;
pCh = (char *)malloc(1000);
if(pCh = NULL)
{
	...内存分配失败的处理代码
}

free函数

void free(void *p)

功能:释放p开头的内存空间(malloc创建的空间大小)
输入:空间的首地址
用法

free(p);
int main()
{
	int *p;	// 整型指针
	p = (int *)malloc(100);	// 动态分配100个字节,注意此时的强制转换类型
	// 等效于: int array[25]		// 数组名array,就是这个数组的首地址
									// array[0],array[1]数组使用下标来访问
	p[0] = 1;
	p[1] = 2;

	printf("%d, %d\n", p[0], p[1]);

	free(p);		// 释放

	return 0;
}

二、线性表的链式表示和实现

#include <stdlib.h>
#include <stdio.h>

// 定义一个结构体类型
struct Student{

	int num;
	char name[10];

	struct Student* next;		// 指向本结构体的指针
};		// 后面要加分号

int main()
{
	struct Student *pStd1, *pStd2;	// 定义了 2 个Student结构体的指针
	pStd1 = (struct Student*)malloc(sizeof(struct Student));	// 动态分配一个Student结构体
	pStd2 = (struct Student*)malloc(sizeof(struct Student));

	pStd1->next = pStd2;	// 通过next指向pStd2;

	pStd1->num = 1;
	pStd2->num = 2;

	printf("%d\n", pStd1->num);
	//printf("%d\n", pStd2->num);
	printf("%d\n", pStd1->next->num);	// 通过next获取第二个学号

	free(pStd1);
	//free(pStd2);
	free(pStd1->next);

	return 0;
}

输出结果为: 1 2

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值