int GetLinkListElem(LinkList *L, int i) { int j = 0; LinkList *p = L->next; // p指向链表第一个结点 while (p && j < i) { // 遍历链表,直到找到第i个结点或到达链表末尾 p = p->next; j++; } if (!p || j > i) { // 找不到第i个结点,或者 i 的值不合法 printf("第 %d 个元素不存在!\n", i); return 0; } else { return p->data; } }
时间: 2024-03-29 08:36:52 浏览: 43
这段代码的作用是获取链表中第i个元素的值。下面是代码的详细解释:
- 首先定义一个变量j,初始化为0,用于记录当前遍历到的结点位置。
- 定义一个指针变量p,指向链表的第一个结点,即头结点的下一个结点。
- 在while循环中,当p不为NULL且j小于i时,不断遍历链表,直到找到第i个结点或到达链表末尾。
- 如果在while循环中遍历到了第i个结点,就返回该结点的值p->data。
- 如果while循环结束后p为NULL或j大于i,则说明链表中不存在第i个元素,输出错误信息并返回0。
需要注意的是,链表中第一个结点是头结点,而不是真正的数据结点。因此,指针p应该初始化为L->next,而不是L。
相关问题
#include <iostream> using namespace std; #define Maxsize 200 #define ERROR 0 typedef struct Node { char data; struct Node* next; int length; } Linklist; Linklist* Initlist() { Linklist* T; T = new Linklist; T->next = NULL; T->length = 0; return T; } void StrAssign(Linklist*& T, char str[]) { T = Initlist(); Linklist* p = T; for (int i = 0; str[i] != '\0'; i++) { Linklist* s = new Linklist; s->data = str[i]; p->next = s; p = s; T->length++; } p->next = NULL; } Linklist* Concat(Linklist* S1, Linklist* S2) { Linklist* p1, * p2, * L, * p, * r; int len1 = 0, len2 = 0; L = Initlist(); r = L; p1 = S1->next; while (p1) { p = new Linklist; p->data = p1->data; p1 = p1->next; p->next = NULL; r->next = p; r = p; len1++; } r->next = NULL; p2 = S2->next; while (p2) { p = new Linklist; p->data = p2->data; p2 = p2->next; p->next = NULL; r->next = p; r = p; len2++; } L->length = len1 + len2; return L; } Linklist* Substr(Linklist* L, int pos, int len) { if (pos > L->length || pos < 1 || pos + len > L->length || len < 0) return ERROR; Linklist* p, * r, * l, * rr; l = Initlist(); r = L->next; rr = l; for (int i = 1; i < pos; i++) r = r->next; for (int i = 0; i < len; i++) { p = new Linklist; p->data = r->data; r = r->next; p->next = NULL; rr->next = p; rr = p; } l->length = len; return l; } void Replace(Linklist* L, Linklist T, Linklist V) { L = L->next; Linklist* headT = T.next; while (L) { if (L->data == headT->data) { Linklist* t = headT->next; Linklist* l = L->next; for () } } } void print(Linklist* L) { Linklist* p = L->next; while (p) { cout << p->data; p = p->next; }
这段代码是关于单链表的字符串操作,包括字符串初始化、拼接、子串截取和替换。其中,Initlist()函数用于初始化一个链表,StrAssign()函数用于将一个字符数组转化成链表存储,Concat()函数用于将两个链表拼接成一个新的链表,Substr()函数用于截取一个链表的子串,Replace()函数用于将链表中的某个子串替换成另一个链表。print()函数用于输出链表的内容。
#include<stdio.h> #define MAXSIZE 100 #include<malloc.h> typedef struct node{ int data; struct node*next; }LNode,*Linklist; void create(Linklist L){ int m; Linklist s; s=L; while(1){ scanf("%d",&m); if(m==0)break; Linklist p=(Linklist)malloc(sizeof(LNode)); p->data=m; p->next=NULL; s->next=p; s=p; } } int lentgh(Linklist L){ Linklist p=L->next; int len=0; while(p){ p=p->next; len++; } return len; } void Bobblesort(Linklist L){ int len=lentgh(L); Linklist p; int a; for(int i=0;i<len-1;i++){ p=L->next; for(int j=0;j<len-i-1;j++){ if(p->data>p->next->data) { a=p->next->data; p->next->data=p->data; p->data=a; } p=p->next; } } } void Delete(Linklist L){ Linklist p=L->next; while(p->next){ if(p->data==p->next->data) { Linklist tmp=p->next; p->next=p->next->next; free(tmp); }p=p->next; } } void output(Linklist L){ Linklist p; p=L->next; while(p){ printf("%d ",p->data); p=p->next; } } int main(){ Linklist L; L=(Linklist)malloc(sizeof(LNode)); create(L); Bobblesort(L); Delete(L); output(L); }为什么不对
这段代码存在以下问题:
1.在create函数中,传入的参数是Linklist类型,即指向节点的指针,但是在函数内部对其进行修改时,并没有传入指向指针的指针,导致在函数外部无法获取到链表的头指针。
2.在Delete函数中,当p->data==p->next->data时,应该先判断p->next是否为NULL,否则会出现访问NULL指针的错误。
3.在Delete函数中,当删除节点时,应该将p指向被删除节点的前一个节点,否则会出现遍历不完整的情况。
4.在main函数中,应该对L进行初始化,即将L指向NULL,否则L中会存在随机值,导致程序出现未知错误。
下面是修改后的代码:
```c
#include<stdio.h>
#include<malloc.h>
#define MAXSIZE 100
typedef struct node{
int data;
struct node *next;
}LNode, *Linklist;
void create(Linklist *L){
int m;
Linklist s;
*L = (Linklist)malloc(sizeof(LNode));
s = *L;
while(1){
scanf("%d",&m);
if(m == 0) break;
Linklist p = (Linklist)malloc(sizeof(LNode));
p->data = m;
p->next = NULL;
s->next = p;
s = p;
}
}
int len(Linklist L){
Linklist p = L->next;
int len = 0;
while(p){
p = p->next;
len++;
}
return len;
}
void BubbleSort(Linklist L){
int i, j, len = len(L);
Linklist p;
int a;
for(i = 0; i < len - 1; i++){
p = L->next;
for(j = 0; j < len - i - 1; j++){
if(p->data > p->next->data){
a = p->next->data;
p->next->data = p->data;
p->data = a;
}
p = p->next;
}
}
}
void Delete(Linklist L){
Linklist p = L->next;
Linklist tmp;
while(p != NULL && p->next != NULL){
if(p->data == p->next->data){
tmp = p->next;
p->next = tmp->next;
free(tmp);
}else{
p = p->next;
}
}
}
void output(Linklist L){
Linklist p;
p = L->next;
while(p){
printf("%d ",p->data);
p = p->next;
}
}
int main(){
Linklist L = NULL;
create(&L);
BubbleSort(L);
Delete(L);
output(L);
return 0;
}
```
注意:这里修改后的代码仅仅是修正了代码的问题,但是并没有改变代码的逻辑,所以如果前面存在的逻辑错误,还需要根据具体需求进行修改。
阅读全文