求出不带头结点的单链表中的最大值并返回
时间: 2024-05-01 13:18:46 浏览: 172
好的,这个问题很简单,可以通过遍历链表,比较每个节点的值来得出最大值,下面是代码示例:
```
int getMax(Node* head) {
if (head == NULL) {
return -1; // 空链表返回-1
}
int max_val = head->val;
Node* p = head->next;
while (p != NULL) {
if (p->val > max_val) {
max_val = p->val;
}
p = p->next;
}
return max_val;
}
```
当然,这里假设单链表中元素都是正整数。如果有负数,可以将 `max_val` 初值设为链表第一个节点的值,而不是0。
相关问题
本题要求求出不带头结点的单链表中的最大值并返回。 /* 求单链表值最大的结点 */ int getMaxNode(LinkNode* head) { if (head == NULL) return INT_MIN; int first = head->data; int m = ; if (m > first)return m; else return first; }
这里给出的代码是不完整的,需要在其中填写求单链表中最大值的代码。
可以使用一个变量m来记录遍历过程中的最大值,遍历整个链表,依次比较每个节点的值与m的大小,如果比m大,则更新m的值。最后返回m即可。
代码如下:
```
/* 求单链表值最大的结点 */
int getMaxNode(LinkNode* head) {
if (head == NULL)
return INT_MIN;
int m = head->data;
LinkNode* p = head->next;
while (p != NULL) {
if (p->data > m)
m = p->data;
p = p->next;
}
return m;
}
```
注意,这里假设链表中至少有一个节点,如果链表为空,则返回INT_MIN表示没有最大值。
补全代码:本题要求求出不带头结点的单链表中的最大值并返回。 /* 求单链表值最大的结点 */ int getMaxNode(LinkNode* head) { if (head == NULL) return INT_MIN; int first = head->data; int m = ; if (m > first)return m; else return first; }
可以使用一个指针变量p遍历整个链表,依次比较每个节点的值与m的大小,如果比m大,则更新m的值。最后返回m即可。
补全后的代码如下:
```
/* 求单链表值最大的结点 */
int getMaxNode(LinkNode* head) {
if (head == NULL)
return INT_MIN;
int first = head->data;
int m = first;
LinkNode* p = head->next;
while (p != NULL) {
if (p->data > m)
m = p->data;
p = p->next;
}
return m;
}
```
注意,这里假设链表中至少有一个节点,如果链表为空,则返回INT_MIN表示没有最大值。
阅读全文