解题思路:
        1.输入

        2.创建a链表

        3.输出a链表看一下输入对不对


        4.创建b链表

        5.输出b链表看一下输入对不对

        6.连接a,bl链表

        7.冒泡排序

        8.输出连接后的整个链表+释放链表

如有错误请包涵(第一次发这么认真的题解)我是小白呀,呀呀!逃~

注意事项:

参考代码:

#include<stdio.h>
#include<stdlib.h>  //  malloc函数的头文件 
typedef struct node
{
 int id;
 int score;
 struct node* next;//存放下一个节点(类型为 node )的地址,所以指针类型为 node 
}Node;
int main()
{
      int n,m; 
      Node *p , *p1 , *p2 , *head1 , *head2 , *q1 , *q2; 
            /* 
              p是存放链表 动态创建的node类型节点的地址 
              head是存放链表的首地址
              q是指向当前节点的地址 
          */ 
      scanf("%d%d",&n,&m); //输入两个链表分别有多少个节点 
      
      p1 = (Node*)malloc(sizeof(Node));        // 动态生成一个首节点(node类型的结构体) 
                                                       //并把节点的地址赋值给p1,及p1指向首节点 
                   
      head1 = p1;                              //把首节点的地址放给head1只要通过head1就可以遍历a链表 
      
      q1 = p1;                                 // q1指向当前节点    
      
      scanf("%d%d",&p1->id,&p1->score);//输入学号  成绩 
      
      p1->next = NULL;                //把p1的next 指针赋空(相当于标记   便于链表的遍历)
        
      for(int i = 1;i < n ; i++){           //动态生成n-1个节点 (前面已经创建了一个) 
      p1 = (Node*)malloc(sizeof(Node));    //动态生成一个节点(node类型的结构体)并把节点的地址赋值给p1
      
       scanf("%d%d",&p1->id,&p1->score);        //输入学号  成绩 
       
       p1->next = NULL;                //把p1的next 指针赋空(相当于标记   便于链表的遍历)
       
       q1->next = p1;     //首先要明确此时q1指向的是当前的节点,而p1指向的是新创建的节点,
                         //要想使新的节点连接到之前的链表中, 
                        //只要把p1(新的节点的地址)的地址赋值给q1(当前节点的地址)的next(指向下一个节点的地址),
                                   //即q1指向新节点(新节点与之前的那一段链表连接上了) 
            
       q1 = p1;                    //因为新节点连接成功所以,新节点是变成了当前节点,
                                  //所以把新节点的地址(p1)赋值给q1(始终指向当前节点)
         
      }
      /* 
      p=head1;
      cout<<"1*****"<<endl;
      while(p!=NULL){
            printf("%d %d\n",p->id,p->score);
           p=p->next;               //这是一段链表输出的代码,看一下链表生成的对不对 
      }
      cout<<"1*****"<<endl;
      */
      p2 = (Node*)malloc(sizeof(Node));                //跟上面的是一样的所以就偷懒了
      head2 = p2;
      q2 = p2;         
      scanf("%d%d",&p2->id,&p2->score);
      p2->next = NULL; 
      for(int i = 1 ; i < m ; i++){
           p2 = (Node*)malloc(sizeof(Node));
           scanf("%d%d",&p2->id,&p2->score);
           p2->next = NULL;
           q2->next = p2;
           q2 = p2;  
      }
      /* 
      p=head2; 
      cout<<"2*****"<<endl;
      while(p!=NULL){   
           printf("%d %d\n",p->id,p->score);
           p=p->next;
      }
      cout<<"2*****"<<endl;
      */     //跟上面的是一样的所以就偷懒了  
      
      q1->next = head2;             //要想连接两链表只需要把 b 链表 的指针赋值给 a链表
                                   //最后一个节点中的next指针(next指向了b链表,这样就连接成功了)
          
      // 链表的排序--冒泡排序    
      p1 = head1;  
      p2 = head1;
      int t;
      for(int i = 1 ; i < n+m ; i++){
            for(int j = 1 ; j <= n+m-i ; j++){
            p2 = p2->next;                  //没做一次就指向下一个节点有点像冒泡里面的 j++; 
            if(p1->id>p2->id){             //当p1指向的学号大于p2指向的学号则交换   
            
                 t = p2->id;
                 p2->id = p1->id;              //交换学号 
                 p1->id = t;
         
                 t = p2->score;
                 p2->score = p1->score;        //交换成绩 
                 p1->score = t;
             }
       }
       p1 = p1->next;                      //没做一次就指向下一个节点有点像冒泡里面的 i++; 
       p2 = p1;                           //使p2指针前移 
      } 
      //链表输出   +   链表释放 
      p = head1;  
      Node *h;                            //释放节点的指针 
      while(p != NULL){   
           printf("%d %d\n",p->id,p->score); //输入学号  成绩 
           h = p;         
           p = p->next;                      //当把p的地址赋值给h指针后,指向下一个节点   
           free(h);                          //释放h节点(此时p的上一个节点) 
      }
     return 0;
    }

-------------------------------------------------------------------------------------------------------------------------------------------------

-------------------------------------------------------------------------------------------------------------------------------------------------

无注释

#include<stdio.h>
#include<stdlib.h>
typedef struct node
{
 int id;
 int score;
 struct node* next;
}Node;
int main()
{
 int n,m; 
 Node *p,*p1,*p2,*head1,*head2,*q1,*q2;
 
 scanf("%d%d",&n,&m);
 
 p1 = (Node*)malloc(sizeof(Node));
 
 head1 = p1;
 
 q1 = p1;
 scanf("%d%d",&p1->id,&p1->score);
 
 p1->next = NULL; 
 
 for(int i = 1 ; i < n ; i++){
  
  p1 = (Node*)malloc(sizeof(Node));
  
  scanf("%d%d",&p1->id,&p1->score);
  
  p1->next = NULL;
  
  q1->next = p1;
  
  q1 = p1;  
 }
 p2 = (Node*)malloc(sizeof(Node));
 
 head2 = p2;
 
 q2 = p2;
 
 scanf("%d%d",&p2->id,&p2->score);
 
 p2->next = NULL; 
 
 for(int i=1;i<m;i++){
  
   p2 = (Node*)malloc(sizeof(Node));
   scanf("%d%d",&p2->id,&p2->score);
   p2->next = NULL;
   q2->next = p2;
   q2 = p2;  
 } 
 q1->next=head2;
 p1 = head1;
 p2 = head1;
 int t;
 for(int i = 1 ; i < n+m ; i++){
   for(int j = 1;j <= n+m-i ; j++){
    
     p2 = p2->next;
     
     if(p1->id > p2->id){
      t = p2->id;
      p2->id = p1->id;
      p1->id = t;
    
      t = p2->score;
      p2->score = p1->score;
      p1->score = t;
     }
   }
   
   p1=p1->next;
   p2=p1;
 } 
 p = head1;
 Node *h; 
 while(p != NULL){ 
   
   printf("%d %d\n",p->id,p->score);
   h = p;
   p = p->next;
   free(h);
 }
 return 0;
}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论