本题要求实现两个函数,分别将读入的数据存储为单链表、将链表中奇数值的结点重新组成一个新的链表。链表结点定义如下:
struct ListNode {
int data;
ListNode *next;
};
函数接口定义
struct ListNode *readlist();
struct ListNode *getodd( struct ListNode **L );
函数readlist从标准输入读入一系列正整数,按照读入顺序建立单链表。当读到−1时表示输入结束,函数应返回指向单链表头结点的指针。
函数getodd将单链表L中奇数值的结点分离出来,重新组成一个新的链表。返回指向新链表头结点的指针,同时将L中存储的地址改为删除了奇数值结点后的链表的头结点地址(所以要传入L的指针)。
裁判测试程序样例:
#include <stdio.h>
#include <stdlib.h>
struct ListNode {
int data;
struct ListNode *next;
};
struct ListNode *readlist();
struct ListNode *getodd( struct ListNode **L );
void printlist( struct ListNode *L )
{
struct ListNode *p = L;
while (p) {
printf("%d ", p->data);
p = p->next;
}
printf("\n");
}
int main()
{
struct ListNode *L, *Odd;
L = readlist();
Odd = getodd(&L);
printlist(Odd);
printlist(L);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例1:
1 2 2 3 4 5 6 7 -1
输出样例1:
1 3 5 7
2 2 4 6
答案代码块
//此方法思路是:getodd函数中将原链表中奇数添加至奇数表输出,将原链表中的奇数删除用作偶数链表。方法有一点复杂不太推荐
//另一个思路是:getodd函数中新建两个链表判断奇数偶数分别添加至奇数链表和偶数链表。方法较为易懂。代码中没有写此方法
struct ListNode *readlist(){
int data = 0 ;
struct ListNode *pHead = NULL;
struct ListNode *pEnd , *pNew;
while(scanf("%d",&data) && data != -1){
pNew = (struct ListNode*)malloc(sizeof(struct ListNode));//动态分配内存
if(pNew!=NULL){
pNew->data=data; //新增数据
pNew->next=NULL;
}
if( pHead != NULL){
pEnd->next = pNew; //pEnd经过赋值过后指向了这个结构体所以直接使用pEnd->next = pNew;
}else{ //如果pHead==null也就是第一次运行
pHead = pNew; //此时赋值的是地址
}
pEnd = pNew; //此时赋值的是地址
}
return pHead; //返回首地址
}
struct ListNode *getodd( struct ListNode **L ){
int data;
struct ListNode *pHead = NULL;
struct ListNode *pEnd = NULL , *pNew;
struct ListNode *q , *pL ,*hL;
hL =pL = *L; //记录L首地址
for( q = NULL ; pL ; q = pL,pL = pL->next ){
data = pL->data;
if( data % 2 != 0 ){ //将奇数添加至新链表
pNew = (struct ListNode *)malloc(sizeof(struct ListNode));
if(pNew != NULL){
pNew->data = data;
pNew->next = NULL;
}
if( pHead != NULL){
pEnd->next = pNew;
}else{
pHead = pNew;
}
pEnd = pNew;
if(q){ //q不为null时 将q->next等于pL的后一个
q->next=pL->next;
free(pL); //删除pL地址
pL = q; //否则循环的 pL = pL->next会报错
}
else{ //q为null时 首地址指向下一个地址
hL = pL->next;
}
}
}
if(hL){ //如果hL不为空(输入值只有一个奇数时)
data=hL->data;
if(data%2!=0){ //判断偶数链表第一个数是否是奇数
hL=NULL; //如果是偶数则将首地址改为null,
}
}
*L = hL; //返回偶数链表地址
return pHead;
}