考研真题:桂林理工大学2020年硕士研究生入学考试真题C语言程序设计

对于正在备考的同学们来说,真题是非常重要的学习资料,暨南大学公布了2020年的考研真题,计划报考暨南大学的同学们可要赶紧收藏哦,以下是小编整理的“考研真题:桂林理工大学2020年硕士研究生入学考试真题C语言程序设计”的相关内容,点击即可查看!

桂林理工大学2020年硕士研究生入学考试试题

考试科目代码:877 

考试科目名称:C语言程序设计 A卷

               (总分150分,三小时答完)                        

考生注意:1.请将答题写在答卷纸上,写在试卷上视为无效。

2.考试需带   ╳╳╳   用具

一、选择题(每小题2分,共30分)

1.以下(                ) 是错误的整型常量。

A. -0xabcdef          B. 018          C. 0x29          D. 011

2.为了判断两个字符串s1和s2是否相等,应当使用(            )。

A.  if(s1==s2)                          B.  if(s1=s2)              

C.  if(strcmp (s1,s2) == 1)             D.  if(strcmp(s1,s2) == 0)

3.以下scanf函数调用语句中错误的是 (         )。

  struct student

  {  char name[20];

     int age;

  }pup[5], *p;

  p=pup;

A.   scanf("%d", p->age);        B.   scanf("%s", pup[1].name);

C.   scanf("%d", &(p->age));    D.   scanf("%s", p->name);

4. 以下程序运行结果(              )。

        #include <stdio.h>

int main( ) 

{

             int sum=0,item=0;

             while (item<5) 

             { 

                item++; 

                sum+=item;

                if(sum>=8) 

             break;

               }

              printf("%d\n",sum) ;

              return 0;

}

A. 15            B. 10            C. 6               D. 9

5.下面程序段的运行结果是(               )。

#include <stdio.h>

int main( )

{

   int i=0, a[]={3,4,5,4,3};

   do{

      a[i]++;

   }while(a[++i]<5);

   for(i=0;i<5;i++)

      printf("%d ",a[i]);

   return 0;

}

A.  4 5 6 5 4      B. 3 4 5 4 3    C. 4 5 5 5 4      D. 4 5 5 4 3

6.以下程序的输出结果是(             )。

  #include <stdio.h>

int main( )

{   int a[9]={1,2,3,4,5,4,3,2,1};

int *p,*q,i,x;

p=&a[0];  q=&a[8];

for (i=0;i<=4;i++)

if(*(p+i) == *(q-i) )

               x=*(p+i)*2;

printf("%d\n",x);

return 0;

}

A. 2         B.  18         C. 10          D.  不确定

7.以下程序段的运行结果是(               )。

  #include <stdio.h>

int main( )

{ int a[12]={1,2,3,4,5,6,7,8,9,10,11,12}, *p[4],i;

    for(i=0;i<4;i++)

      p[i]=&a[i*3];

    printf("%d\n",p[3][2]);  

    return 0;

}

A.11       B.  12       C. 8      D.  9

8.要把一个函数计算结果的两个整型数据返回给主调函数,在下面的方法中不正确的是(        )。

A.  用两个return语句              B. 形参用数组,该数组包含两个整型数据

C.  形参用两个整型的指针          D. 用两个整型全局变量

9.若已定义:int a[ ]={0,1,2,3,4,5,6,7,8,9},*p=a, i=3; 则对a数组元素不正确的引用是  (                 )。

  A.a[p-a]         B.p[i]            C.*(&a[i])          D.a[p+a]

10.下列程序段的输出结果是(          )。

#include <stdio.h>

#include <string.h>

int main( )

{

char s[20]="abcd",*p2="ABCD",str[50]="xyz";

strcpy(str+2, strcat(s+2,p2+1));

printf("%s\n", str);  

     return 0;

A. xyabcAB        B. abcABz       C. ABabcz       D. xycdBCD

11.若有定义:int a=7; double x=2.5,y=4.7; 则表达式x+a%3*(int)(x+y)%2/4的值是(        )。

A.   2.500000       B. 2.750000         C. 3.500000        D. 0.000000

12.对于语句  int *p[10]; ,以下说法正确的是(                    )。

 A. p是一个指针,指向一个数组,数组的元素是整型数据

 B. p是一个指针,指向一个数组,数组中有10个整型数据

 C. p是一个数组,它的每一个元素是指向整型数据的指针

D. p是一个数组,它的每一个元素是指向10个整型数据的指针

13.下面程序的输出结果是(          )。

  #include <stdio.h>

#include <string.h>

int main (  )

{

    int i;

    char *s= "abcd";

    for ( i=0 ; i<strlen(s); i++)

       printf ("%s\n" ,s+i );

  return 0;

}

A.abcd           B. abcd               C. d            D. d

abc               bcd                   cd              dc

ab                cd                    bcd             dcb

a                 d                     abcd            dcba

14.若a,b为整型变量,语句:printf("%d",(a=3)&&(b=-3)); 的输出结果是(          )。

  A.   3         B.  -3       C.  1           D. 0

15.下列函数欲实现对两个整型变量的值进行交换,下列说法正确的是(               )。

void  swap(int x, int y)

{  int t;

   t=x;  x=y;  y=t;

}

主函数中定义变量int a, b;  调用函数的语句为 swap(&a, &b)

A. 程序有错,调用语句应为swap(a, b);    B.程序有错,函数swap缺少return语句

C. 程序有错,应将swap函数中的形参x,y,局部变量t定义为整型指针类型,执行语句不变 

D. 以上说法都不正确

二、填空题(每空2分,共30分)

1. 在C语言中存储字符串 "abcdef" 至少需要(                        )个字节。

2. 用if语句实现与以下赋值语句 k=a>b?(b>c?1:0):0;一样的功能, 对应的if语句为

(                                                  )。

3. 在C程序中有自定义函数f,函数首部为:void f(int *x),主函数中有数组定义为 int a[5],以数组a为实参,则调用该函数的语句为(                           )。

4. 使用malloc函数,分配能够存储4个double数据的内存空间,并将起始地址赋值给指针变量p,变量p已经定义:double *p; 相应的赋值语句是(                        )。

5. 以下程序的输出结果是(                      )。

  #include <stdio.h>

#define PT 5.5

#define S(x) PT*x*x

int main( )

{    int a=1,b=2;

         printf("%.1f\n" ,S(a+b)); 

         return 0;

 }

 6. 如果指针fp所指向的文件未结束,函数feof(fp)的返回值为(                        )。

 7. 若有以下定义:

struct link{

      int data;

        struct link *next;

}*head, *p;

 并已建立如下图所示的链表结构,第1个结点为10所在结点,第2个结点为30所在结点。

head

指针P指向如下结点:

p

则能够把p所指结点插入到链表中,成为链表第2个结点的程序段是

(                                                                            )。

 8.下列程序的输出结果是(                                 )。

       #include <stdio.h>

int main( )

      {   int i;

          for(i=0;i<3;i++)

          switch(i)

         {   case 1: printf("%d",i);

             case 2: printf("%d",i);

             default: printf("%d",i);

         }

       return 0;       }

 9. 以下函数的功能是(                                                    ) 。

int function(char *x) 

{

char *p=x; 

while(*p++); 

return(p-x-1);

}

10. 若有定义:int a=10,b=8,c; 则执行语句c=(a&b)>>2; 变量c的值为(               )。

11. 以下程序的功能是统计输入的字符串中数字字符的个数并输出,输入换行符时结束,请分析程序并填空。

 #include <stdio.h>

int main( )

{

   int n=0; char c;

   while (                        )

     if (                          )

n++; 

   printf("n=%d\n",n);

   return 0;

}

12. 函数fun的函数首部为:int  fun(int i,int j)且函数指针变量P定义如下:int(*P)(int i,int j);则使指针P指向函数fun的赋值语句是(                           )。

13. 若有定义结构体及函数定义如下,函数fun所实现的功能是(                              )。

  struct node{

int data;

struct node *next;

};

void fun(struct node *head)

{

struct node *p=head;

while(p)

{  if ((p->data%)%2)

               printf("%d",p->data);

           p=p->next;

}

}

14. 有以下语句,执行之后变量k的值是(                      )。

  int a[5]={2,4,6,8,10},*p, k;

  p=&a[2];

  k=*(--p);  

三、程序阅读题。 (每小题5分,共30分)

1. 写出以下程序的输出结果。

          #include <stdio.h>

int main( )

 {  int  x, y;

            for(x=30, y=0; x>=10, y<10; x--, y++)

                 x/=2, y+=2;

            printf("x=%d,y=%d\n",x,y);

          return 0;

}

2. 请写出以下程序的运行结果。

              #include<stdio.h>

int z=0;

void f(int *x, int y)

{

              ++*x;

              y--;

              z=*x+y+z;

              printf("%d %d %d\n",*x,y,z);

}

int main( )

{

                int x=1, y=5,z=9;

                f(&x,y);

                printf("%d %d %d\n",x,y,z);

                return 0;

}

3. 阅读以下程序,说明函数f实现的功能是什么,并写出主函数运行后的输出结果。

            #include <stdio.h>

void f(int *a,int n)

{   int i,t;

                for(i=0;i<n/2;i++)

                  {  t=a[i];a[i]=a[n-1-i];a[n-1-i]=t;}

}

int main( )

{   int b[10]={1,2,3,4,5,6,7,8,9,10}; int i,s=0;

                f(b+2,5);

               for(i=5;i<10;i++)

 s+=b[i];

               printf("%d\n",s);

             return 0;

}

4.  请写出以下程序的运行结果。

            #include <stdio.h>

int f(int *a,int n)

{   if(n>1) 

return a[0] + f(&a[1],n-1);

                else

 return a[0];

}

int main( )

{   int aa[ ]={1,2,3,4,5},s;

    s=f(&aa[0],sizeof(aa)/sizeof(int));

printf("%d\n",s);

return 0;

}

5. 请写出以下程序的运行结果。

              #include <stdio.h>

int fun(int k)

{

                  static int a=0;

                  a+=k;

                  return a;

}

int main( )

{  int i,s=0;

               for (i=1; i<=4; i++)

                    s=s+fun(i);

                printf("s=%d\n",s);

                return 0;

}

6. 请写出下列程序的运行结果。

#include <stdio.h>

#include <string.h>

int main( )

 char ch[3][5]={"135","246","789"},*p[3];

             int i,j,s=0;

             for(i=0;i<3;i++) p[i]=ch[i];

             for(i=0;i<3;i++)

              for(j=0;p[i][j]>='0'&&p[i][j]<='9';j+=2)

            s=10*s+p[i][j]-'0';

            printf("%d\n",s); 

            return 0;

}

四、编程题。 1,2,3小题每小题10分,4,5小题每小题15分,共60分。

1. 黑洞数也称为陷阱数,又称“Kaprekar问题”,是一类具有奇特转换特性的数。任何一个各位数字不全相同的三位数,经有限次“重排求差”操作,总会得到495。最后所得的495即为三位黑洞数。所谓“重排求差”操作即组成该数的数字重排后的最大数减去重排后的最小数。例如,对三位数207:第1次重排求差得:720 - 27 = 693;第2次重排求差得:963 - 369 = 594;第3次重排求差得:954 - 459 = 495;编写程序,实现如下功能:输入一个三位整数,输出将其转换为黑洞数的过程,输入输出格式为:

     输入: 207

     输出: 1:720-27=693

 2:963-369=594

 3:954-459=495

     如果输入的三位数字全部相同,则只输出一次重排求差过程,值为0就停止。

2. 编写一个函数,实现字符串的复制,函数首部定义为:char * str_copy(char *d, char *s)

     函数功能为:将第二个参数s所表示的字符串复制到第一个参数d所表示的字符串中,函数返回值为第一个参数的值。请写出完整的函数,并写出主函数,对该函数进行验证。 (说明:本题不允许使用string.h中的标准函数,不允许改变函数首部)

3. Fibonacci数列定义如下:第1,第2个数均为1,从第3个数开始,该数是其前面两个数之和。Fibonacci数列为:1,1,2,3,5,8,13,… 。编写递归函数,求Fibonacci数列的第n个数,并编写主函数,调用该递归函数,输出数列第60个数的值。

4. 编写一个函数,函数功能为判断一个整数是否为质数。并写出主函数,调用该函数,将10000之内的所有质数输出到屏幕,每行输出10个数据,并统计一共有多少个质数;并将这些质数依次写入一个文件中,文件名为zhishu.dat,文件中的格式与输出格式一致。

5. 定义一个结构体类型描述图书的基本信息,一本图书的基本信息包括:编号,书名,作者,价格。  

编写程序,实现如下功能:(1)输入10本书的信息,保存在结构体数组中。(2)输出10本图书中价格最高的图书信息。(3)对结构体数组按照价格进行升序排列,排序之后,下标为0的数组成员存放价格最低的图书信息,…下标为9的数组成员存放价格最高的图书信息。

点击查看:C语言程序设计

原文标题:2020年考研真题

原文链接:https://yjsy.glut.edu.cn/info/1189/4400.htm

以上就是“考研真题:桂林理工大学2020年硕士研究生入学考试真题C语言程序设计”的相关内容,更多考研信息,请持续关注。

X

扫码添加获取各院校复试名单及录取名单

【版权与免责声明】本站所提供的内容除非来源注明研线网,否则内容均为网络转载及整理,并不代表本站赞同其观点和对其真实性负责。文章由本站编辑整理发出,仅供个人交流学习使用。如本站稿件涉及版权等问题,请联系本站管理员予以更改或删除。

责任编辑:史梦洁