《C语言及程序设计》实践参考——拆分链表

返回:贺老师课程教学链接

【项目2-拆分链表】
编写一个函数将一个头指针为a的单链表A分解成两个单链表A和B,其头指针分别为a和b,使得A链表中含有原链表A中序号为奇数的元素,而B链表中含有原链表A中序号为偶数的元素,且保持原来的相对顺序。例,建立长度为7,元素为1 2 3 4 5 6 7的链表后,经拆分,得到两个数组A和B,其元素分别是1 3 5 7 和2 4 6

[参考解答]

#include <stdio.h>
#include <stdlib.h>
typedef struct s
{
    int date;
    struct s *link;
} S;
S *creat(int n)
{
    S *p,*q,*head;
    head=p=q=malloc(sizeof(S));
    scanf("%d",&p->date);
    while(--n)
    {
        p=malloc(sizeof(S));
        scanf("%d",&p->date);
        q->link=p;
        q=p;
    }
    q->link=NULL;
    return head;
}
void play(S *h,int n)
{
    S *p,*q,*h1=h,*h2=h->link;
    int i;
    for(p=h1,q=h2,i=0; p!=NULL && q!=NULL && i<(n+1)/2-1; i++)
    {
        p->link=p->link->link;
        q->link=q->link->link;
        p=p->link;
        q=q->link;
    }
    if(!(n%2))
    {
        q=NULL;
        p=NULL;
    }
    else
        p->link=NULL;
    for(p=h1,i=1; i<=(n+1)/2; p=p->link,i++)
        printf("%d ",p->date);
    printf("\n");
    for(p=h2,i=1; p!=NULL; p=p->link,i++)
        printf("%d ",p->date);
    printf("\n");
}
int main()
{
    int n;
    scanf("%d",&n);
    play(creat(n),n);
    return 0;
}
时间: 2024-10-24 13:23:22

《C语言及程序设计》实践参考——拆分链表的相关文章

C语言及程序设计进阶例程-18 链表中结点的插入和删除

贺老师教学链接  C语言及程序设计进阶 本课讲解 回顾:动态分配和撤销内存 #include <stdio.h> #include <malloc.h> struct Student { int num; float score; struct Student *next; }; int main( ) { struct Student *p; p=malloc(sizeof(struct Student)); p->num=31001; p->score=89.5;

C语言及程序设计进阶例程-19 链表应用

贺老师教学链接  C语言及程序设计进阶 本课讲解 猴子选大王 #include <stdio.h> #include <malloc.h> struct Monkey { int num; //猴子的编号 struct Monkey *next; //下一只猴子 }; int main() { int m,n,i,j,king; struct Monkey *head, *p1,*p2; scanf("%d %d", &m, &n); if(n=

《C语言及程序设计》实践参考——改造链表

返回:贺老师课程教学链接 [项目3 - 改造链表] 下面是一个建立动态链表的程序.阅读程序,然后按要求改造程序. #include <iostream> using namespace std; #include <stdio.h> #include <malloc.h> #define N 5 typedef struct NODE { int data; //结点的数据 struct NODE *next; //指向下一结点 } Node; Node *head=N

《C++语言基础》实践参考—— 链表类

返回:贺老师课程教学链接  项目要求 [项目 - 链表类]动态链表也是程序设计中的一种非常有用的数据结构.可以说,是否能够理解有关操作的原理,决定了你是否有资格称为"科班"出身.在后续的专业基础课中,相关的内容还会从不同的角度,反复地认识,反复地实践.不过,在现阶段多些体验,也是很有必要的了.(1)阅读下面的程序,回顾一下动态链表,阅读程序过程中,请用笔画一画形成链表的过程中指针值的变化. #include <iostream> using namespace std; s

《C++语言基础》实践参考——Josephus(约瑟夫环)问题

返回:贺老师课程教学链接  项目要求 [项目-Josephus(约瑟夫环)问题]n个小孩子围成一圈,从第一个小孩子开始顺时针方向数数字,到第m个小孩子离开,这样反反复复,最终只剩下一个小孩子,求第几个小孩子留下?    提示:约瑟夫环即是一个首尾相连的链表,在建立好这个环以后,从头结点开始,每次间隔m孩子删除一个结点,直至只余下一个结点(删除了n-1个).     参考下面的代码,也可以自行设计类. //链表结点kid,其中number为这个人的编号 struct kid { int numbe

《C++语言基础》实践参考——旱冰场造价

返回:贺老师课程教学链接 [项目1 - 旱冰场造价] 有一个圆形的旱冰场地,场地内抹水泥,造价为每平方米M元,围栏用木条围成,每米造价N元,输入旱冰场半径,用程序计算出其造价. 一级提示: 先定义类,确定其数据成员和成员函数.在这里要定义的旱冰场类,实际我们只关心其面积和周长,根据面积计算场地内抹水泥的造价,根据周长计算围栏的造价.有了类的定义,在main函数中定义该类对象,调用成员函数即可以完成求解.二级提示: 实际上,对于旱冰场,我们只关心它就是一个圆.这就是设计中抓住了本质.于是,设计一个

《C++语言基础》实践参考——指向学生类的指针

返回:贺老师课程教学链接 [项目4-指向学生类的指针] 设计一个学生类Student,数据成员包括学号(num)和成绩(score),成员函数根据需要自行设计(建议配备需要的set.get函数,以及必要的输入或输出,给出的代码中也可以找到需要成员函数的线索).在main函数中,要做到: 建立一个对象数组,通过初始化,设置5个学生的数据,要求: 用指针指向数组首元素,输出第1.3.5个学生的信息: 设计一个函数int max(Student *arr);,用指向对象的指针作函数参数,在max函数中

《C++语言基础》实践参考——复数模板类

返回:贺老师课程教学链接 [项目6-复数模板类]    阅读教材例10.1.该例实现了一个复数类,但是美中不足的是,复数类的实部和虚部都固定只能是double型的.可以通过模板类的技术手段,设计Complex,使实部和虚部的类型为定义对象时指定的实际类型.    (1)要求类成员函数在类外定义.    (2)在此基础上,再实现减法.乘法和除法    你可以使用的main()函数如下. int main( ) { Complex<int> c1(3,4),c2(5,-10),c3; //实部和虚

《C++语言基础》实践参考——友元类

返回:贺老师课程教学链接 [项目5-友元类]定义下面两个类的成员函数(为体验友元类,实际上本例并不一定是一个好的设计,将两个类的合并为一个DateTime,日期.时间都处理更好) class Date; //对Date类的提前引用声明 class Time { public: Time(int,int,int); void add_a_second(Date &); //增加1秒,1秒后可能会到了下一天,乃到下一月.下一年 void display(Date &); //显示时间,格式:月