2024年大数据最全【数据结构,2024年最新阿里中间件

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

#endif


#### sqlist.c



#include"c1.h"
#define MAXSIZE 100
typedef int ElemType;

typedef struct{
ElemType *elem;
int length;
}SqList;

Status InitList_Sq(SqList *L);
int GetElem(SqList L,int i,ElemType *e);
int LocateElem(SqList L,ElemType e);
Status ListInsert_Sq(SqList *L,int i ,ElemType e);
Status ListDelete_Sq(SqList *L,int i);
void DestroyList(SqList *L);
void ClearList(SqList *L);
int GetLength(SqList L);
int IsEmpty(SqList L);

Status InitList_Sq(SqList *L)
{
L->elem=(ElemType )malloc(sizeof(ElemType) MAXSIZE);
if(L->elem==NULL)
exit(OVERFLOW);
L->length=0;
return OK;
}

int GetElem(SqList L,int i,ElemType *e)
{
if (i<1||i>L.length)
return ERROR;
*e=L.elem[i-1];
return OK;
}

int LocateElem(SqList L,ElemType e)
{
int i;
for (i=0;i<=L.length-1;i++)
if (L.elem[i]==e)
return i+1;
return 0;
}

Status ListInsert_Sq(SqList *L,int i ,ElemType e)
{
int j;
if(i<1 || i>L->length+1)
return ERROR;
if(L->length==MAXSIZE)
return ERROR;
for( j=L->length-1;j>=i-1;j-- )
L->elem[j+1]=L->elem[j];
L->elem[i-1]=e;
++L->length;
return OK;
}

Status ListDelete_Sq(SqList *L,int i)
{
int j;
if(i<1||i>L->length)
return ERROR;
for (j=i;j<=L->length-1;j++)
L->elem[j-1]=L->elem[j];
L->length–;
return OK;
}

void DestroyList(SqList *L)
{
if (L->elem)
free(L->elem);
}

void ClearList(SqList *L)
{
L->length=0;
}

int GetLength(SqList L)
{
return L.length;
}

int IsEmpty(SqList L)
{
if (L.length==0)
return OK;
else
return ERROR;
}


#### number.c



#include"sqlist.c"
void menu();
void PrintList(SqList L);
void DeleteAll(SqList* L,ElemType e);
void menu()
{
printf(“顺序表功能选择界面\n”);
printf(“1.初始化顺序表\n”);
printf(“2.插入\n”);
printf(“3.批量输入\n”);
printf(“4.输出\n”);
printf(“5.删除第i个元素\n”);
printf(“6.删除与值e相等的所有元素\n”);
printf(“0.退出\n”);
}
void PrintList(SqList L)
{
int i;
if(L.length==0)
{
printf(“当前顺序表为空表!\n”);
}
else
{
printf(“顺序表的当前元素:”);
for(i=1;i<=L.length;i++)
{
printf(“%d “,L.elem[i-1]);
}
printf(”\n”);
}
}
void DeleteAll(SqList *L,ElemType e)
{
int i,x,L_len;
L_len=GetLength(*L);
for(i=1;i<=L_len;i++)
{
x=LocateElem(*L,e);
if(x!=0)
ListDelete_Sq(L,x);
else
break;
}
}
int main()
{
SqList L;
ElemType e;
int choose,temp,i,n;
menu();
while(1)
{

	printf("\n请选择功能:");
	scanf("%d",&choose);
	switch(choose)
	{
		case  1:
			temp=InitList_Sq(&L);
			if(temp==OK)
			{
				printf("顺序表初始化成功!\n");
				printf("顺序表空间的起始化为:%x\n",L.elem);
				printf("顺序表的当前长度为:%d\n",L.length);
				printf("顺序表的当前最大容量为:%d\n",MAXSIZE);
			}
			else
			{
				printf("顺序表初始化失败!");
				return 0; 
			}
			break;
		case  2:
			printf("请输入要插入的元素位置:");
			scanf("%d",&i);
			printf("请输入要插入元素的值:");
			scanf("%d",&e);
			temp=ListInsert_Sq(&L,i,e);
			if(temp==OK)
			{
				printf("插入元素成功!\n");
				PrintList(L);
			 } 
			 else
			 printf("插入失败!\n");
			break;
		case  3:
			printf("请输入要插入元素的个数:");
			scanf("%d",&n);
			printf("请输入要插入的元素(用空格分隔):");
			for(i=1;i<=n;i++)
			{
				scanf("%d",&e);
				temp=ListInsert_Sq(&L,L.length+1,e);
				if(temp==ERROR)
				{
					printf("插入第%d个元素失败!\n",i);
					break;
				}
			 } 
			 if(i>n)
			 	printf("请输入元素成功!\n");
			 	PrintList(L);
			
			break;
		case  4:
			PrintList(L);
			break;
			break;
		case  5:
			printf("请输入要删除的元素位置:");
			scanf("%d",&i);
			ListDelete_Sq(&L,i);
			if(temp==ERROR)
			printf("删除失败!\n");
			else
			{
				printf("删除成功!\n");
				PrintList(L);
			 } 
			break;
		case  6:
			printf("请输入要删除的值:"); 
			scanf("%d",&e);
			DeleteAll(&L,e);
			PrintList(L);
			break;
		case  0:
			printf("退出系统\n");
			return 0;
		default:
			printf("输入错误,请重新输入!\n");	
			break;			
	}
}
return 0;

}


![](https://img-blog.csdnimg.cn/5b95930ad9904722867c578cdfb42c38.png)




---


## 单链表的增删查改


####  c1.h



#ifndef C1_H
#define C1_H

#include<string.h>
#include<stdio.h> /* EOF(=^Z或F6),NULL /
#include<stdlib.h> /
malloc()等 /
#include<math.h> /
floor(),ceil(),abs() */

/* 函数结果状态代码 /
#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
/
#define OVERFLOW -2 因为在math.h中已定义OVERFLOW的值为3,故去掉此行 /
typedef int Status; /
Status是函数的类型,其值是函数结果状态代码,如OK等 /
typedef int Boolean; /
Boolean是布尔类型,其值是TRUE或FALSE */

#endif


#### stuscore.c



#include"c1.h"
typedef struct student
{
char num[6];
char name[20];
int score1,score2,score3;
struct student *next;
}LNode,*LinkList;
void menu();
void CreateList_L(LinkList *L,int n);
void Print_L(LinkList L);
int ListInsert_L(LinkList *L,int i,LNode e);
int ListDelete_L(LinkList *L,int i);
void Print_L(LinkList L);
void help();
//查询学生信息函数
//修改学生信息
//保存学生信息

void help()//辅助系统
{
printf(“\n0.欢迎使用系统帮助!\n”);
printf(“\n1.初次进入系统后,请先选择学生成绩单链表的创建;\n”);
printf(“\n2.按照菜单提示键入数字代号;\n”);
printf(“\n3.增加学生信息后,请输出学生信息,查验;\n”);
printf(“\n4.谢谢您的使用!\n”);
printf(“\n”);
}

void menu()
{
printf(“学生成绩管理系统\n”);
printf(“1.学生成绩单链表的创建\n”);
printf(“2.插入学生信息\n”);
printf(“3.删除学生信息\n”);
printf(“4.输出学生信息\n”);
printf(“0.退出”);
}
void CreateList_L(LinkList *L,int n)
{
LinkList r,p;
int i;
(*L)=(LinkList)malloc(sizeof(LNode));
r=(*L);
for(i=1;i<=n;i++)
{
p=(LinkList)malloc(sizeof(LNode));
printf(“请输入第%d位学生的学号 姓名 成绩(用空格分隔我):”,i);
scanf(“%s %s %d %d %d”,p->num,p->name,&p->score1,&p->score2,&p->score3);

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

num,p->name,&p->score1,&p->score2,&p->score3);

[外链图片转存中…(img-mBw8pHw9-1715598621387)]
[外链图片转存中…(img-teFPn2Dp-1715598621387)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值