草庐IT

计算机等级考试二级C语言模拟试卷(一)

I am a teacher! 2023-03-28 原文

一、选择题(每小题1分,共40分)

(1)数据的存储结构是指    

A)存储在外存中的数据

B)数据所占的存储空间量

C)数据在计算机中的顺序存储方式

D)数据的逻辑结构在计算机中的表示

(2)下列关于栈的描述中,错误的是    

A)栈是先进后出的线性表 

B)栈只能顺序存储

C)栈具有记忆作用

D)对栈的插入与删除操作中,不需要改变栈底指针

(3)对于长度为n的线性表,在最坏情况下,下列各排序法所对应的比较次数中正确的是  

A)冒泡排序为n/2                                      B)冒泡排序为n

C)快速排序为n                                         D)快速排序为n(n-1)/2

(4)对长度为n的线性表进行顺序查找,在最坏情况下所需要的比较次数为  

A)log2n                    B) n/2                       C) n                             D) n+1

(5)下列对于线性链表的描述中正确的是        

A)存储空间不一定是连续,且各元素的存储顺序是任意的

B)存储空间不一定是连续,且前件元素一定存储在后件元素的前面

C)存储空间必须连续,且前件元素一定存储在后件元素的前面

D)存储空间必须连续,且各元素的存储顺序是任意的

(6)下列对于软件的描述中正确的是        

A)软件测试的目的是证明程序是否正确

B)软件测试的目的是使程序运行结果正确

C)软件测试的目的是尽可能多地发现程序中的错误

D)软件测试的目的是使程序符合结构化原则

(7)为了使模块尽可能独立,要求    

A)模块的内聚程序要尽量高,且各模块间的耦合程序要尽量强

B)模块的内聚程序要尽量高,且各模块间的耦合程序要尽量弱

C)模块的内聚程序要尽量低,且各模块间的耦合程序要尽量弱

D)模块的内聚程序要尽量低,且各模块间的耦合程序要尽量强

(8)下列描述中正确的是        

A)程序就是软件

B)软件开发不受计算机系统的限制

C)软件既是逻辑实体,又是物理实体

D)软件是程序、数据与相关文档的集合

(9)数据独立性是数据库技术的重要特点之一。所谓数据独立性是指  

A)数据与程序独立存放

B)不同的数据被存放在不同的文件中

C)不同的数据只能被对应的应用程序所使用

D)数据与程序间的互不依赖性,包括数据的物理独立性和数据的逻辑独立性

(10)用树形结构表示实体之间联系的模型是    

A)关系模型               B)网状模型            C)层次模型                 D)面向对象模型

(11)以下选项中可作为C语言合法常量的是    

A)-80                         B)-080                  C)-8e1.0                      D)-80.0e

(12)以下叙述中,正确的是        

A)用C程序实现的算法必须要有输入和输出操作

B)用C程序实现的算法可以没有输出但必须要有输入

C)用C程序实现的算法可以没有输入但必须要有输出

D)用C程序实现的算法可以既没有输入也没有输出

(13)以下不能定义为用户标识符的是  

A)Main                     B)_0                      C)_int                         D)sizeof

(14)以下选项中,不能作为合法常量的是    

A)1.234e04               B)1.234e0.4            C)1.234e+4                 D)1.234e0

(15)数字字符0的A SCII值为48,若有以下程序

main()

{   char  a='1',b='2';

     printf("%c,",b++);

     printf("%d\n",b-a);

}

程序运行后的输出结果是      

A)2,2                        B)3,2                     C)2,50                        D)50,2

(16)有以下程序

main()

{   int m=12,n=34;

     printf("%d%d",m++,++n);

     printf("%d%d\n",n++,++m);

}

程序运行后的输出结果是    

A)12353514                B)12353513             C)12343514                  D)12343513

(17)有定义语句:int  b; char  c[10];  ,则正确的输入语句是    

A)scanf("%d%s",&b,&c);                              B)scanf("%d%s",&b,c);

C)scanf("%d%s",b,c);                                  D)scanf("%d%s",b,&c);

(18)有以下程序

main()

{   int  m,n,p;

    scanf("m=%dn=%dp=%d",&m,&n,&p);

    printf("%d%d%d\n",m,n,p);

}

若想从键盘上输入数据,使变量m中的值为123,n中的值为456,p中的值为789,则正确的输入是  

A)m=123n=456p=789                                 B)m=123  n=456  p=789

C)m=123,n=456,p=789                                D)123   456   789

(19)有以下程序

main()

{

   int  a,b,d=25;

   a=d/10%9;

   b=a&&(-1);

   printf("%d,%d\n",a,b);

}

程序运行后的输出结果是      

A)2,0                         B)2,1                       C)6,0                            D)6,1

(20)有以下程序

main()

{     int  i=1,j=2,k=3;

      if (i++==1&&(++j==3||k++==3))

        printf("%d  %d  %d\n",i,j,k);

}

程序运行后的输出结果是  

A)1  2  3                    B)2  3  4                  C)2  2  3                       D)2  3  3

(21)若整型变量a、b、c、d中的值依次为:1、4、3、2。则条件表达式a<b?a:c<d?c:d的值   

A)1                            B)2                          c)3                               D)4

(22)有以下程序

main()

{   char  a[7]="a0\0a0\0";int  i,j;

     i=sizeof(a);  j=strlen(a);

     printf("%d  %d\n",i,j);

}

程序运行后的输出结果是     

A)2    2                      B)6    2                    C)7    2                         D)7    6

 (23)有以下程序

main()

{

   int p[8]={11,12,13,14,15,16,17,18},i=0,j=0;

   while(i++<7)  if(p[i]%2)   j+=p[i];

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

}

程序运行后的输出结果是    

A)42                          B)45                        C)56                             D)60

 (24)以下能正确定义一维数组的选项是    

A)int  a[5]={0,1,2,3,4,5};                               B)char  a[]={0,1,2,3,4,5};

C)char  a={'A','B','C'};                                   D)int  a[5]="0123";

(25)有以下程序

int  f1(int  x,int  y) {return  x>y?x:y;}

int  f2(int  x,int  y) {return  x>y?y:x;}

main()

{   int  a=4,b=3,c=5,d=2,e,f;

     e=f2(f1(a,b),f1(c,d));

    f=f1(f2(a,b),f2(c,d));

   printf("%d,%d\n",e,f);

}

程序运行后的输出结果是                 

A)2,5                       B)3,4                    C)4,3                         D)5,2

(26)有以下程序

void  f(int  *x,int  *y)

{     int  t;

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

}

main()

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

     p=a;q=&a[7];

     while(p<q)

    {

      f(p,q);

      p++;

      q--;

    }

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

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

}

程序运行后的输出结果是                       

A)8,2,3,4,5,6,7,1,                     B)5,6,7,8,1,2,3,4,

C)1,2,3,4,5,6,7,8,                     D)8,7,6,5,4,3,2,1,

(27)有以下程序

main()

{

   int  a[3][3],*p,i;

   p=&a[0][0];

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

       p[i]=i;

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

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

}

程序运行后的输出结果是              

A)0 1 2                      B)1 2 3                    C)2 3 4                         D)3 4 5

(28)以下叙述中错误的是    

A)对于double类型数组,不可以直接用数组名对数组进行整体输入或输出

B)数组名代表的是数组所占存储区的首地址,其值不可改变

C)当程序执行中,数组元素的下标超出所定义的下标范围时,系统将给出“下标越界”的出错信息

D)可以通过赋初值的方式确定数组元素的个数

(29)有以下程序

#define  N  20

fun(int  a[],int  n,int m)

{   int i,j;

     for(i=m;i>=n;i--)

        a[i+1]=a[i];

}

main()

{

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

   fun(a,2,9);

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

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

}

程序运行后的输出结果是   

A)10234                     B)12234                   C)12334                       D)12344

(30)有以下程序

main()

{

   int  c=35;  printf("%d\n",c&c);

}

程序运行后的输出结果是                            

A) 0                          B) 1                        C) 35                           D) 70

(31)程序中若有如下的说明和定义语句

char  fun(char  *);

main()

{

   char  *s="one",a[5]={0},(*f1)()=fun,ch;

   ……

}

以下选项中,对函数fun的正确调用语句是                    

A)(*f1)(a);               B)*f1(*s);                C)fun(&a);                    D)ch=*f1(s)

(32)以下叙述中,正确的是                  

A)预处理命令行必须位于源文件的开头

B)在源文件的一行上可以有多条预处理命令

C)宏名必须用大写字母表示

D)宏替换不占用程序的运行时间

(33)若有以下说明和定义

union  dt

{

    int  a;   char  b;  double  c;

}data;

以下叙述中错误的是                          

A)data的每个成员起始地址都相同

B)变量data所占内存字节数与成员c所占字节数相等

C)程序段:data.a=5; printf("%f\n",data.c);输出结果为5.000000

D)data可以作为函数的实参

(34)以下语句或语句组中,能正确进行字符串赋值的是        

A)char  *sp;  *sp="right!";                            B)char s[10];  s="right!";

C)char  s[10];  *s="right!";                            D)char  *sp="right!";

(35)有以下程序

main()

{

   int  a=1,b;

   for(b=1;b<=10;b++)

   {

      if(a>=8)   break;

      if(a%2==1)  {  a+=5;  continue;}

      a-=3;

   }

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

}

程序运行后的输出结果是              

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

(36)有以下程序

main()

{

   char  s[]="159",*p;

   p=s;

   printf("%c",*p++);

   printf("%c",*p++);

}

程序运行后的输出结果是              

A)12                          B)15                        C)16                             D)59

(37)有以下函数

fun(char  *a,char  *b)

{

   while((*a!='\0')&&(*b!='\0')&&(*a==*b))

   {   a++;   b++;}

   return  (*a-*b);

}

该函数的功能是                                       

A)计算a和b所指字符串的长度之差

B)将b所指字符串复制到a所指字符串中

C)将b所指字符串连接到a所指字符串后面

D)比较a和b所指字符串的大小

(38)有以下结构体说明和变量定义,如图所示,指针pqr分别指向此链表中三个连续结点。

struct  node

{

     int data;  

     struct node  *next;

} *p,*q,*r;

现要将q所指结点从链表中删除,同时保持链表的连续,以下不能完成指定操作的语句是  

 

A)p->next=q->next;                                      B)p->next=p->next->next;

C)p->next=r;                                                D)p=q->next;

(39)以下与函数fseek(fp,0L,SEEK_SET)有相同作用的是              

A)feof(fp)                  B)ftell(fp)                C)fgetc(fp)                    D)rewind(fp)

(40)有以下程序

#include  "stdio.h"

void WriteStr(char  *fn,char  *str)

{

   FILE  *fp;

   fp=fopen(fn,"W");

   fputs(str,fp);

   fclose(fp);

}

main()

{

   WriteStr("t1.dat","start");

   WriteStr("t1.dat","end");

}

程序运行后,文件t1.dat中的内容是                        

A)start                        B)end                      C)startend                     D)endrt

 二、程序填空题(18分)

函数fun的功能是:计算

 

的前n项。若x=2.5,函数值为12.182340。

请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。

注意:部分源程序在文件BLANK1.C中。不得增行或删行,也不得更改程序的结构。

试题程序:

#include  <stdio.h>
double fun(double  x, int  n)
{  
    double  f, t;  int  i;
    f = 1.0;
/**********found**********/
    t=___1___;
/**********found**********/
    for(i=___2___;i<n;i++)
    {
/**********found**********/
       t*=x/___3___;
       f += t;
    }
    return  f;
}
int main()
{  
    double  x, y;
    x=2.5;
    y = fun(x, 12);
    printf("The result is :\n");
    printf("x=%-12.6f,y=%-12.6f\n", x, y);
    return 0;
}

三、程序修改题(18分)

下列给定程序中fun函数功能是:将n个无序整数从小到大排序。请改正程序中的错误,使它能得出正确的结果。注意:部分源程序在文件MODI1.C中,不得增行或删行,也不得更改程序的结构!

试题程序:

#include <stdio.h>
#include <stdlib.h>
fun ( int  n, int  *a )
{  
    int  i, j, p, t;
    for ( j = 0; j<n-1 ; j++ )
    {  
       p = j;
/************found************/
       for (i=j+1; i<n-1 ; i++ )
         if ( a[p]>a[i] )
/************found************/
             t=i;
       if ( p!=j )
       { t = a[j]; a[j] = a[p]; a[p] = t; }
    }
}
void putarr( int  n,  int  *z )
{  
    int  i;
    for ( i = 1; i <=  n; i++, z++ )
    {  
        printf( "%4d", *z );
        if ( !( i%10 ) )  printf( "\n" );
    } 
    printf("\n");
}
int main()
{  
    int  aa[20]={9,3,0,4,1,2,5,6,8,10,7}, n=11;
    printf( "Before sorting %d numbers:\n", n ); 
    putarr( n, aa );
    fun( n, aa );
    printf( "After sorting %d numbers:\n", n ); 
    putarr( n, aa );
    return 0;
}

四、程序设计题(24分)

编写函数int fun(int lim, int aa[MAX]),其功能是求出小于或等于lim的所有素数并放在aa数组中,并返回所求出的素数的个数。

注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。

试题程序:

#include<conio.h>
#include<stdio.h>
#include<stdlib.h>
#define MAX 100
int fun(int lim, int aa[MAX])
{

}
void main()
{
   FILE *wf;
   int limit,i,sum;
   int aa[MAX];
   system("CLS");
   printf("输入一个整数:");
   scanf("%d",&limit);
   sum=fun(limit,aa);        
   for(i=0;i<sum;i++)
   {
      if(i%10==0&&i!=0)    /*每行输出10个数*/
         printf("\n ");
      printf("%5d ",aa[i]);
   }
   wf=fopen("out.dat","w");
   sum=fun(15,aa);        
   for(i=0;i<sum;i++)
   {
      if(i%10==0&&i!=0)    /*每行输出10个数*/
         fprintf(wf,"\n");
      fprintf(wf,"%5d ",aa[i]);
   }
   fclose(wf);
}    
一、选择题
( 1)~(10):D B D C A  C B D D C
(11)~(15):A C D B A  A B A B D
 (21)~(30):A C B B C  D D C C C
(31)~(40):A D C D B  B D D D B
二、程序填空题
(11.0213)i
三、程序改错题
  (1)错误: for (i=j+1; i<n-1 ; i++ )
         正确: for (i=j+1; i<n ; i++ )
  (2)错误: t=i;
         正确: p=i; 
四、程序设计题
    int i,j,k=0;
    for (i=2;i<=lim;i++)
    {
        for (j=2;j<i;j++)
            if (i%j==0) break;
        if (j>=i)
            aa[k++]=i;
    }
        return k;
参考答案:
模拟试卷等级考试nbspstylespanC语言

有关计算机等级考试二级C语言模拟试卷(一)的更多相关文章

  1. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  2. ruby - 如何模拟 Net::HTTP::Post? - 2

    是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou

  3. ruby-on-rails - 使用一系列等级计算字母等级 - 2

    这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,

  4. ruby - 寻找通过阅读代码确定编程语言的ruby gem? - 2

    几个月前,我读了一篇关于ruby​​gem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:

  5. Unity 热更新技术 | (三) Lua语言基本介绍及下载安装 - 2

    ?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------

  6. 7个大一C语言必学的程序 / C语言经典代码大全 - 2

    嗨~大家好,这里是可莉!今天给大家带来的是7个C语言的经典基础代码~那一起往下看下去把【程序一】打印100到200之间的素数#includeintmain(){ inti; for(i=100;i 【程序二】输出乘法口诀表#includeintmain(){inti;for(i=1;i 【程序三】判断1000年---2000年之间的闰年#includeintmain(){intyear;for(year=1000;year 【程序四】给定两个整形变量的值,将两个值的内容进行交换。这里提供两种方法来进行交换,第一种为创建临时变量来进行交换,第二种是不创建临时变量而直接进行交换。1.创建临时变量来

  7. 计算机毕业设计ssm+vue基本微信小程序的小学生兴趣延时班预约小程序 - 2

    项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU

  8. ruby - 如何计算 Liquid 中的变量 +1 - 2

    我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我

  9. ruby - 使用 Ruby,计算 n x m 数组的每一列中有多少个 true 的简单方法是什么? - 2

    给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in

  10. ruby-on-rails - 在这种情况下我如何模拟一个对象?没有明显的方法可以用模拟替换对象 - 2

    假设我在Store的模型中有这个非常简单的方法:defgeocode_addressloc=Store.geocode(address)self.lat=loc.latself.lng=loc.lngend如果我想编写一些不受地理编码服务影响的测试脚本,这些脚本可能已关闭、有限制或取决于我的互联网连接,我该如何模拟地理编码服务?如果我可以将地理编码对象传递到该方法中,那将很容易,但我不知道在这种情况下该怎么做。谢谢!特里斯坦 最佳答案 使用内置模拟和stub的rspecs,你可以做这样的事情:setupdo@subject=MyCl

随机推荐