刚刚调试出来,趁热写一下。
输入多个整数,以-1作为结束标志,顺序建立一个带头结点的单链表,之后对该单链表的数据进行逆置,并输出逆置后的单链表数据。
Input
输入多个整数,以-1作为结束标志。
Output
输出逆置后的单链表数据。
Sample Input
12 56 4 6 55 15 33 62 -1
Sample Output
62 33 15 55 6 4 56 12
Hint
不得使用数组。
这里借用网上的图片讲一下:
1.刚开始顺序链表是这样的:
开始令 p=head;
2.然后另开一个 *New,令New指向NULL:
3.然后就要交换1和2节点,需要借助另一个 *temp帮助交换,因为如果直接讲将节点2的 next直接指向1,那后面的3,4,5就找不到,在2那里丢失了,先令 temp=p->next(将后面的地址暂时存到temp里面),然后p->next=New(即把当前p代表的节点与New连接)然后令New=p(下次在进行上述操作时,就是将再后面的一个节点2连在节点1上,