设为首页 加入收藏

TOP

2013年计算机二级C语言上机题库第四十套及答案解析
2014-11-23 20:15:00 】 浏览:1882
Tags:2013年 计算机 二级 语言 上机 题库 四十 答案 解析

  填空题
  给定程序中已建立一个带有头结点的单向链表,链表中的各结点按结点数据域中的数据递增有序链接。函数fun的功能是:把形参x的值放入一个新结点并插入到链表中,插入后各结点数据域的值仍保持递增有序。
  请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
  注意:源程序存放在考生文件夹下的BLANK1.C中。
  不得增行或删行,也不得更改程序的结构!
  给定源程序:
  #include
  #include
  #define N 8
  typedef struct list
  { int data;
  struct list *next;
  } SLIST;
  void fun( SLIST *h, int x)
  { SLIST *p, *q, *s;
  s=(SLIST *)malloc(sizeof(SLIST));
  s->data=___1___;
  q=h;
  p=h->next;
  while(p!=NULL && x>p->data) {
  q=___2___;
  p=p->next;
  }
  s->next=p;
  q->next=___3___;
  }
  SLIST *creatlist(int *a)
  { SLIST *h,*p,*q; int i;
  h=p=(SLIST *)malloc(sizeof(SLIST));
  for(i=0; i   { q=(SLIST *)malloc(sizeof(SLIST));
  q->data=a[i]; p->next=q; p=q;
  }
  p->next=0;
  return h;
  }
  void outlist(SLIST *h)
  { SLIST *p;
  p=h->next;
  if (p==NULL) printf("\nThe list is NULL!\n");
  else
  { printf("\nHead");
  do { printf("->%d",p->data); p=p->next; } while(p!=NULL);
  printf("->End\n");
  }
  }
  main()
  { SLIST *head; int x;
  int a[N]={11,12,15,18,19,22,25,29};
  head=creatlist(a);
  printf("\nThe list before inserting:\n"); outlist(head);
  printf("\nEnter a number : "); scanf("%d",&x);
  fun(head,x);
  printf("\nThe list after inserting:\n"); outlist(head);
  }
   解题思路:
  本题是要求在一个有序的链表中插入一个数,插入后各结点仍然是有序的。程序中共有三要填上适当的内容,使程序能运行出正确的结果。
  第一处:在函数fun的开始处,已经对结构指针s分配了内存,其中data是一个整型变量,实际要求填入一个整型数据。根据本题要求在一个链表插入一个整型数,该数已通过函数的形参x传入,因此应填x。
  第二处:使用一个while循环找出要插入一个数的位置,在循环体中q实际上保留当前链表p位置的临时变量,如果x>p->data时,那么再移动链表指针到下一个结果,再进行判断是否符合条件,如果仍大于,则仍q保留链表p的位置。因此,此处应填p。
  第三处:当找到结点位置后,就要插入这个数,完成插入过程。由于函数体中分配了结构指针s,s的next指针已经指向了p,所以,当前位置q的next指针就应该指向指针s完成链表的链接。因此,此处应填s。


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇2013年计算机二级C语言上机题库第.. 下一篇2013年9月全国计算机二级C语言程..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目