//删除单链表中最大元素
Del-max(link a){
int tmp;
element *p;
element *max;
p=a; //指针,用于遍历链表,取数与当前最大结点值比较
max=a; //指针,用于记录最大元素所在位置(未考虑有多个最大元素)
tmp=p->data; //变量,用于记录当前最大结点值
while(a->next!=null){
p=p->next;
if(p->data>tmp){ 、//如果当前指针所指结点值大于当前tmp所保留的值,则记录
max=p; //当前位置(放入到max),记录当前最大值(放入tmp)
tmp=p->data;
} //end of if
} //end of while
tmp=max->next->data; //一次遍历后max指针所指结点就是最大元素,删除之。。。
max->data=tmp;
max->next=max->next->next; //删除方法能看懂么?好好思考。。。
}//end of Del-max
追问max->next=max->next->next;你的这句有问题吧,应该是max的前驱=max的next.
追答没问题的:删除指针当前所指结点你会用什么办法?我的办法是取当前指针所指的下一个结点值然后赋给当前结点,再把下个结点删掉。比如A->B->C->D四个结点,当前指针指在B,你想删除B结点,那么我就把C的值赋给B结点,单链表变为A->C->C->D,现在当前指针指在第一个C上,现在我删除掉当前指针的下个结点也就是第二个C,单链表就变为A->C->D,成功删除B
本回答被提问者采纳