第一个函数中的第8行:
ListNode* prev = &dummy;
Have a error: Call object type 'ListNode *' is not a function or function pointer
以下是.cpp中的代码:
ListNode* deleteDuplicatesII(ListNode* head)
{
if (head == nullptr) return nullptr;
ListNode dummy(-1);
dummy.next = head;
ListNode* prev = &dummy; // Error here: Call object type 'ListNode *' is not a function or function pointer
for (ListNode* cur = prev->next(), *next = cur->next; next != nullptr;)
{
if (cur->value == next->value)
{
while (next != nullptr && cur->value == next->value)
{
cur->next = next->next;
delete next;
next = cur->next;
}
prev->next = cur->next;
delete cur;
cur = prev->next; // now the cur == next
if (cur == nullptr) break;
else next = cur->next; // maybe cur is nullptr
}
else
{
prev = cur;
cur = next;
next = next->next;
}
}
return dummy.next;
}
ListNode* Solution::reverseLinkedList(ListNode* head, int m, int n)
{
ListNode dummy(-1);
dummy.next = head;
head = &dummy; // It works well
for (int i = 0; i < m - 1; i++) {
head = head->next;
}
ListNode* prev = head->next;
ListNode* cur = prev->next;
for (int i = m; i < n; i++, cur = prev->next) {
prev->next = cur->next;
cur->next = head->next;
head->next = cur;
}
return dummy.next;
}
这是.h
中的代码struct ListNode
{
ListNode* next;
int value;
ListNode(int v): value(v), next(nullptr){}
};
错误仅发生在第一个函数中。但在第二个功能中效果很好。我试图将局部变量dummy和prev更改为另一个名称。但它总是报告错误。 我真的不知道导致错误的原因。请提供详细信息,我将不胜感激。
答案 0 :(得分:2)
下一步后删除括号.. 在for循环.. 它是一个属性,但是用括号,编译器认为它是一个方法/函数