本题要求实现一个函数,输出带头结点的单链表的的所有结点元素值。
时间: 2023-04-02 12:05:09 浏览: 137
好的,这个问题可以回答。以下是实现该函数的代码:
```c
void printList(Node* head) {
Node* p = head->next;
while (p != NULL) {
printf("%d ", p->data);
p = p->next;
}
}
```
其中,Node 是单链表的结点类型,包含一个整型数据成员 data 和一个指向下一个结点的指针成员 next。head 是指向链表头结点的指针,头结点不存储数据,只用于方便操作链表。该函数从头结点的下一个结点开始遍历链表,依次输出每个结点的数据元素值。
相关问题
写实现一个函数,输出带头结点的单链表的的所有结点元素值
以下是Python语言实现:
```python
class Node:
def __init__(self, val=0, next=None):
self.val = val
self.next = next
def print_linked_list(head: Node) -> None:
cur = head.next
while cur:
print(cur.val, end=' ')
cur = cur.next
```
其中,Node类定义了链表中的结点,包括结点的值和指向下一个结点的指针。print_linked_list函数接受一个带头结点的单链表的头结点作为参数,遍历链表输出所有结点的值。具体实现中,首先将指针cur指向头结点的下一个结点,然后循环遍历链表,输出每个结点的值,并将指针cur指向下一个结点,直到遍历完整个链表。
实现一个函数,输出带头结点的单链表的的所有结点元素值。
假设链表的结构体定义如下:
```
typedef struct ListNode {
int val;
struct ListNode *next;
} ListNode;
typedef struct LinkedList {
ListNode *head;
} LinkedList;
```
则输出函数的实现如下:
```
void printLinkedList(LinkedList *list) {
ListNode *cur = list->head->next;
while (cur != NULL) {
printf("%d ", cur->val);
cur = cur->next;
}
printf("\n");
}
```
解释:
- 首先获取链表的第一个结点,即头结点的下一个结点
- 循环遍历链表,打印每个结点的元素值
- 最后换行输出