zoukankan      html  css  js  c++  java
  • 单链表的拆分

    数据结构实验之链表五:单链表的拆分

    Time Limit: 1000MS Memory limit: 65536K

    题目描述

    输入N个整数顺序建立一个单链表,将该单链表拆分成两个子链表,第一个子链表存放了所有的偶数,第二个子链表存放了所有的奇数。两个子链表中数据的相对次序与原链表一致。

    输入

    第一行输入整数N;;
    第二行依次输入N个整数。

    输出

    第一行分别输出偶数链表与奇数链表的元素个数; 
    第二行依次输出偶数子链表的所有数据;
    第三行依次输出奇数子链表的所有数据。

    示例输入

    10
    1 3 22 8 15 999 9 44 6 1001

    示例输出

    4 6
    22 8 44 6 
    1 3 15 999 9 1001
     1 #include<stdio.h>
     2 #include<stdlib.h>
     3 struct vode
     4 {
     5     int date;
     6     struct vode *next;
     7 };
     8 int main()
     9 {
    10     struct vode *head,*head1,*head2,*tail,*tail1,*tail2,*p,*q;
    11     head=(struct vode *)malloc(sizeof(struct vode ));
    12     head->next=NULL;
    13     tail=head;
    14     int i,n;
    15     scanf("%d",&n);
    16     for(i=1;i<=n;i++)
    17     {
    18         p=(struct vode *)malloc(sizeof(struct vode ));
    19         p->next=NULL;
    20         scanf("%d",&p->date);
    21         tail->next=p;
    22         tail=p;
    23     }
    24     head1=(struct vode *)malloc(sizeof(struct vode ));
    25     head1->next=NULL;
    26     tail1=head1;
    27     head2=(struct vode *)malloc(sizeof(struct vode ));
    28     head2->next=NULL;
    29     tail2=head2;
    30     p=head->next;
    31     int sum1=0,sum2=0;
    32     while(p)
    33     {
    34         if(p->date%2==0)
    35         {
    36             tail1->next=p;
    37             tail1=p;
    38             sum1++;
    39         }
    40         if(p->date%2!=0)
    41         {
    42             tail2->next=p;
    43             tail2=p;
    44             sum2++;
    45         }
    46         p=p->next;
    47     }
    48     printf("%d %d
    ",sum1,sum2);
    49     p=head1->next;
    50     int s=0,j=0;
    51     while(p)
    52     {
    53         if(j>=sum1)break;
    54         if(s==0)
    55         {
    56             printf("%d",p->date);
    57             s=1;
    58         }
    59         else
    60         {
    61             printf(" %d",p->date);
    62         }
    63         p=p->next;
    64         j++;
    65     }
    66     printf("
    ");
    67     p=head2->next;
    68     s=0;
    69     j=0;
    70     while(p)
    71     {
    72         if(j>=sum2)break;
    73         if(s==0)
    74         {
    75             printf("%d",p->date);
    76             s=1;
    77         }
    78         else
    79         {
    80             printf(" %d",p->date);
    81         }
    82         p=p->next;
    83         j++;
    84     }
    85     printf("
    ");
    86     return 0;
    87 }
    View Code
  • 相关阅读:
    docer run 、docker attach 与 docker exec的区别
    filebeat-kafka:WARN producer/broker/0 maximum request accumulated, waiting for space
    json 格式要求
    词法分析
    CSS3 鲜为人知的属性-webkit-tap-highlight-color的理解
    DOMContentLoaded与load的区别
    用vue的自定义组件写了一个拖拽 组件,局部的 只能在自定义元素内的
    浮动元素遇到标准流元素 会发生转角遇到爱
    柯里化函数
    转载一篇关于toString和valueOf
  • 原文地址:https://www.cnblogs.com/kuangdaoyizhimei/p/3264609.html
Copyright © 2011-2022 走看看