线性表
集合AUB=A
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | // La表示A集合,Lb表示B集合。 void unionL(List *La, list Lb) { int La_len, Lb_len, i; ElemType e; La_len = ListLength(*La); Lb_len = ListLength(Lb); for ( i=1; i <= Lb_len; i++ ) { GetElem(Lb, i, &e); if ( !LocateElem(*La, e) ) { ListInsert(La, ++La_len, e); } } } |
线性表的顺序存储结构
1 2 3 4 5 6 | 结构体定义:<br>#define MAXSIZE 20 typedef int ElemType; typedef struct { ElemType data[MAXSIZE]; int length; }SqList; |
1 2 3 4 5 6 7 8 9 10 11 12 | 取数操作: ElemType GetElem(SqList L, int i,ElemType *e){ if (L.length==0||i<1||i<L.length){ return ERROR; } *e=L.data[i-1]; return OK; } int main(){ } |
ListInsert:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | /* 初始条件:顺序线性表L已存在,1<=i<=ListLength(L)。 */ /* 操作结果:在L中第i个位置之前插入新的数据元素e,L长度+1。*/ Status ListInsert(SqList *L, int i, ElemType e) { int k; if ( L->length == MAXSIZE ) // 顺序线性表已经满了 { return ERROR; } if ( i<1 || i>L->length+1) // 当i不在范围内时 { return ERROR; } if ( i <= L->length ) // 若插入数据位置不在表尾 { /* 将要插入位置后数据元素向后移动一位 */ for ( k=L->length-1; k >= i-1; k-- ) { L->data[k+1] = L->data[k]; } } L->data[i-1] = e; // 将新元素插入 L->length++; return OK; } |
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步