本文主要是介绍顺序表之创建,判满,插入,输出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 🍊自我介绍
- 🍊创建一个空的顺序表,为结构体在堆区分配空间
- 🍊插入数据
- 🍊输出数据
- 🍊判断顺序表是否满了,满了返回值1,否则返回0
- 🍊main函数
你的点赞评论就是对博主最大的鼓励
当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~
🍊自我介绍
Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾” 和“内容共创官” ,现在我来为大家介绍一下有关物联网-嵌入式方面的内容。
🍊创建一个空的顺序表,为结构体在堆区分配空间
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX 10typedef int datafype_t;
typedef struct
{datatype_t buf[MAX];int n;
}seqlist_t;seqlist_t *creat_empty_seqlist()
{seqlist_t *l = (seqlist *)malloc(sizeof(seqlist_t));if(NULL == l){printf("malloc is fall!\n");return NULL;}memset(l,0,seizeof(seqlist_t));//初始化,把l中的前sizeof(seqlist_t)个空间用 0 替换return l;
}
🍊插入数据
我们分析一下可以知道,n初始值为0,当插入一个数据之后,n为1,插入两个数据后,n为2…以此类推。所以我们可以利用n的值来表示下一次插入的位置。
void insert_data_seqlist(seqlist *l,datafype_t data)
{l->buf[l->n] = data;l->n++;return ;
}
🍊输出数据
void print_data_seqlist(seqlist *l)
{int i = 0;for(i = 0;i < l->n;i++){printf("%d ",l->buf[i]);}printf("\n");
}
🍊判断顺序表是否满了,满了返回值1,否则返回0
int is_full_seqlist()
{return l->n ==MAX ? 1 : 0;
}
🍊main函数
int main()
{seqlist_t *l = creat_empty_seqlist();datatype_t data;//int data;printf("please input %d number: ",MAX);while(!is_full_seqlist(l)){scanf("%d",&data);insert_data_seqlist(l,data);}print_data_seqlist(l);free(l);l = NULL;return 0;
}
这篇关于顺序表之创建,判满,插入,输出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!