電腦等級考試二級C語言模擬試卷(六)

来源:https://www.cnblogs.com/cs-whut/archive/2022/11/10/16875797.html
-Advertisement-
Play Games

異常 一、異常:就是程式出現不正常的情況。 Throwable Error Exception RuntimeException 非RuntimeException Error:嚴重問題,不處理 Exception:異常類,程式本身可以處理 RuntimeException:編譯期間不檢查,程式出現 ...


一、選擇題(每小題1分,共40分)

(1)下列敘述中正確的是

A)演算法就是程式

B)設計演算法時只需要考慮數據結構的設計

C)設計演算法時只需要考慮結果的可靠性

D)以上三種說法都不對

(2)下列關於線性鏈表的敘述中,正確的是

A)各數據結點的存儲空間可以不連續,但它們的存儲順序與邏輯順序必須一致

B)各數據結點的存儲順序與邏輯順序可以不一致,但它們的存儲空間必須連續

C)進行插入與刪除時,不需要移動表中的元素

D)有序的線性鏈表也可以方便地進行二分查找

(3)下列關於二叉樹的敘述中,正確的是

A)葉子結點總是比度為2的結點少一個

B)葉子結點總是比度為2的結點多一個

c)葉子結點數是度為2的結點數的兩倍

D)度為2的結點數是度為1的結點數的兩倍

(4)軟體按功能可以分為應用軟體、系統軟體和支撐軟體(或工具軟體)。下麵屬於應用軟體的是

A)學生成績管理系統                           B)C語言編譯程式

C)UNIX操作系統                                D)資料庫管理系統

(5)某系統總體結構圖如下圖所示:

 

該系統總體結構圖的深度是

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

(6)程式調試的任務是

A)設計測試用例                                  B)驗證程式的正確性

C)發現程式中的錯誤                           D)診斷和改正程式中的錯誤

(7)下列關於資料庫設計的敘述中,正確的是

A)在需求分析階段建立數據字典         B)在概念設計階段建立數據字典

C)在邏輯設計階段建立數據字典        D)在物理設計階段建立數據字

(8)資料庫系統的三級模式不包括

A)概念模式          B)內模式              C)外模式                D)數據模式

(9)有三個關係R、S和T如下:

 

則由關係R和s得到關係T的操作是

A)自然連接          B)差                     C)交                       D)並

(10)下列選項中屬於面向對象設計方法主要特征的是 

A)繼承                 B)自頂向下          C)模塊化                D)逐步求精

(11)下列敘述中錯誤的是

A)C語言編寫的函數源程式,其文件名尾碼可以是.C

B)C語言編寫的函數都可以作為一個獨立的源程式文件

C)C語言編寫的每個函數都可以進行獨立的編譯並執行

D)一個C語言程式只能有一個主函數

(12)下列關於程式模塊化的敘述,錯誤的是

A)把程式分成若幹相對獨立的模塊,可便於編碼和調試

B)把程式分成若幹相對獨立、功能單一的模塊,可便於重覆使用這些模塊

C)可採用自底向上、逐步細化的設計方法把若幹獨立模塊組裝成所要求的程式

D)可採用自項向下、逐步細化的設計方法把若幹獨立模塊組裝成所要求的程式

(13)下列關於C語言常量的敘述,錯誤的是

A)所謂常量,是指在程式運行過程中,其值不能被改變的量

B)常量分為整型常量、實型常量、字元常量和字元串常量

C)常量可分為數值型常量和非數值型常量

D)經常被使用的變數可以定義成常量

(14)若有定義語句:int a=10;double b=3.14;,則表達式'A'+a+b值的類型是

A)char                   B)int                     C)double                  D)float

(15)若有定義語句:int x=12,y=8,z;,在其後執行語句z=0.9+x/y;,則z的值為

A)1                       B)1.9                     C)2                          D)2.4

(16)若有定義:int a,b;,通過語句scanf("%d;%d",&a,&B);,能把整數3賦給變數a,5

賦給變數b的輸入數據是

A)3 5                    B)3,5                     C)3;5                       D)35

(17)若有定義語句:int k1=10,k2=20;,執行表達式(k1=k1>k2)&&(k2=k2>k1)後,k1和k2的值分別為

A)0和1                B)0和20               C)10和1                 D)10和20

(18)有以下程式

#include  <stdio.h>

main()

{  

        int a=1,b=0;

if (--a) b++;

else if(a==0)  b+=2;

else  b+=3;

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

)

程式運行後的輸出結果是

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

(19)下列條件語句中,輸出結果與其他語句不同的是

A)if  (a)printf("%d\n",x); else printf("%d\n",y);

B)if  (a==0)  printf("%d\n",y); else printf("%d\n",x);

C)if  (a!=0)  printf ("%d\n",x); else printf("%d\n",y);

D)if  (a==0)  printf("%d\n",x); else printf("%d\n",y);

(20)有以下程式

#include   <stdio.h>

main()

int a=7;

while(a--);

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

)

程式運行後的輸出結果是

A)-1                      B)0                       C)1                          D)7

(21)下列不能輸出字元A的語句是(註:字元A和a的ASCIl碼值分別為65和97)

A)printf("%c\n",'a'-32);                    B)printf("%d\n",'A');

C)printf("%c\n",65);                        D)print-f("%c\n",'B'-1);

(22)有以下程式(註:字元a的ASCIl碼值為97)

#include    <stdio.h>

main()

char *s={"abc"};

do

{  printf("%d",*%10);++s;

}while(*s);

)

程式運行後的輸出結果是

A)abc                    B)789                    C)7890                    D)979899

(23)若有定義語句:double a,*p=&a;下列敘述中錯誤的是

A)定義語句中的*號是一個間址運算符

B)定義語句中的*號只是一個說明符

C)定義語句中的P只能存放double類型變數的地址

D)定義語句中,*p=&a把變數a的地址作為初值賦給指針變數p

(24)有以下程式

#include<stdio.h>

double f(double x)

{ return x*x+1;}

void main()

{

    double a=0;

    int i;

    for (i=0;i<30;i+=10)

          a+=f((double)i);

    printf("%5.0f\n",a);

}

程式運行後的輸出結果是

A)401                    B)500                    C)503                      D)1404

(25)若有定義語句:int year=2019,*p=&year;,以下不能使變數year中的值增至2020的

語句是

A)*p+=1;            B)( *p)++;           C)++(*p);              D)*p++;

(26)下列定義數組的語句中錯誤的是

A)int  num[]={1,2,3,4,5,6};

B)int  num[][3]={{1,2},3,4,5,6};

C)int  num[2][4]=({1,2,{3,4},{5,6});

D)int  num[][4]={1,2,3,4,5,6};

(27)有以下程式

#include  <stdio.h>

void fun(int *p)

{  printf(“%d\n”,p[5]);}

main()

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

     fun(&a[3]);

)

程式運行後的輸出結果是

A)5                       B)6                       C)8                          D)9

(28)有以下程式

#include<stdio.h>

#define N 4

void  fun(int a[][N],int b[])

{

       int i;

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

              b[i]=a[i][i]-a[i][N-1-i];

}

void main()

{

    int x[N][N]={{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}};

    int y[N],i;

    fun(x,y);

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

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

   printf("\n");

}

程式運行後的輸出結果是

A)-12,-3,0,0,                              B)-3,-1,1,3,

C)0,1,2,3,                                     D)-3,-3,-3,-3 

(29)有以下函數

int fun(char *x,char *y)

{  int n=0;

    while ((*x=*y)&&*x!='\0') {x++;y++;n++;}

    return n:

)

函數的功能是

A)查找x和y所指字元串中是否有'\0'

B)統計x和y所指字元串中前面連續相同的字元個數

C)將y所指字元串賦給X所指存儲空間

D)統計x和y所指字元串中相同的字元個數

(30)若有定義語句:char *s1="OK",*s2="ok";,以下選項中,能夠輸出"OK"的語句是

A)if(strcmp(s1,s2)=0)  puts(s1);          B)if(strcmp(s1,s2)!=0) puts(s2);

C)if(strcmp(s1,s2)=1)  puts(s1);          D)if(strcmp(s1,s2)!=0) puts(s1);

(31)以下程式的主函數中調用了在其前面定義的fun函數

main()

{  double a[15],k;

    k=fun(a);

}

則以下選項中錯誤的fun函數首部是

A)double fun(double a[15])                    B)double fun(double *A)

C)double fun(double a[])                        D)double fun(double A)

(32)有以下程式

#include <stdio.h>

#include <string.h>

int main()

{

    char a[5][10]={"china","beijing","you","tiananmen","welcome"};

    int i,j;  char t[10];

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

      for(j=i+1;j<5;j++)

         if (strcmp(a[i],a[j])>0)

               { strcpy(t,a[i]); strcpy(a[i],a[j]); strcpy(a[j],t); }

    puts(a[3]);

    return 0;

}

程式運行後的輸出結果是

A)Beijing               B)china                  C)welcome               D)tiananmen

(33)有以下程式

#include <stdio.h>

int f(int m)

{  static int n=0;

   n+=m:

    return n;

}

main()

{   int n=0;

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

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

}

程式運行後的輸出結果是

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

(34)有以下程式

#include <stdio.h>

main()

{  char ch [3][5]={"AAAA","BBB","CC"};

    printf ("%s\n",ch[1]);

}

程式運行後的輸出結果是

A)AAAA               B)BBB                  C)BBBCC                D)CC

(35)有以下程式

#include <stdio.h>

#include <string.h>

void fun(char *w,int m)

{

        char s,*p1,*p2;

        p1=w;  p2=w+m-1;

        while (p1<p2)

       { s=*p1; *p1=*p2; *p2=s; p1++; p2--;}

}

int main()

{

    char a[]="123456";

    fun(a,strlen(a));

    puts(a);

    return 0;

}

程式運行後的輸出結果是

A)116611               B)123456               C)161616                 D)654321

(36)有以下程式

#include <stdio.h>

#include <string.h>

typedef struct

{ char name[9]; char sex; int score[2];}STU;

STU fun(STU a)

{

       STU b={"Zhao",'m',85,90};

       int i;

       strcpy(a.name,b.name);

       a.sex=b.sex;

      for (i=0;i<2;i++) a.score[i]=b.score[i];

      return a;

int main()

{

    STU c={"Qian",'f',95,92},d;

    d=fun(c);

    printf("%s,%c,%d,%d,",d.name,d.sex,d.score[0],d.score[1]);

    printf("%s,%c,%d,%d,",c.name,c.sex,c.score[0],c.score[1]);

    return 0;

}

程式運行後的輸出結果是

A)Zhao,m,85,90,Qian,f,95,92

B)Zhao,m,85,90,Zha0,m,85,90

C)Qian,f,95,92,Qian,f,95,92

D)Qian,f,95,92,Zhao,m,85,90

(37)有以下程式

#include <stdio.h>

main()

{   struct node {int n;stmct node+next;} *p;

    struct  node x[3]={{2,x+l},{4,x+2},{6,NULL}};

    p=x;

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

    printf("%d\n",p->next->n);

}

程式運行後的輸出結果是

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

(38)有以下程式

#include <stdio.h>

main()

{   int a=2,b;

    b=a<<2;

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

)

程式運行後的輸出結果是

A)2                       B)4                       C)6                          D)8

(39)下列選項中敘述錯誤的是

A)C程式函數中定義的賦有初值的靜態變數,每調用一次函數,賦一次初值

B)在C程式的同一函數中,各複合語句內可以定義變數,其作用域僅限本複合語句內

C)C程式函數中定義的自動變數,系統不自動賦確定的初值

D)C程式函數的形參不可以說明為static型變數

(40)有以下程式

#include <stdio.h>

int main()

{

    FILE *fp;

    int k,n,i,a[6]={1,2,3,4,5,6};

    fp=fopen("d2.dat","w");

    for (i=0; i<6; i++) fprintf(fp,"%d\n",a[i]);

    fclose(fp);

    fp=fopen("d2.dat","r");

    for (i=0; i<3; i++) fscanf(fp,"%d%d",&k,&n);

    fclose(fp);

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

    return 0;

}

程式運行後的輸出結果是

A)1,2                    B)3,4                     C)5,6                       D)123,456 

二、程式填空題(18分)

下麵程式中函數fun的功能是檢查一個字元串是否是迴文,當字元串是迴文時,函數返回字元串yes!;否則函數返回字元串no!,併在主函數中輸出。所謂迴文即正向與反向的拼寫都一樣,例如:adgda。

請在程式的下畫線處填入正確的內容並把下畫線刪除,使程式得出正確的結果。

註意:部分源程式在文件BLANK1.C中。不得增行或刪行,也不得更改程式的結構。

試題程式:

#include <stdio.h>
#include <string.h>
/**********found**********/
___1___ fun(char  *str)
{
   char *p1,*p2;
   unsigned int  i,t=0;
   p1=str;  
/**********found**********/
   p2=___2___;
   for (i=0;i<=strlen(str)/2;i++)
      if(*p1++!=*p2--)
      {  t=1; break;  }
/**********found**********/
   if (___3___)  return ("yes!");
   else    return ("no!");
}
int main()
{ 
   char  str[50];
   printf("Input:");  
   scanf("%s",str);
   printf("%s\n",fun(str) );
   return 0;
}

三、程式修改題(18分)

下列給定程式中,函數fun的功能是:根據下麵的公式求π的近似值。形參n給出了公式右邊的項數,如n=4表示π/4=1-1/3+1/5-1/7。例如,給定實參項數的值為5000,則程式運行後,輸出為PI = 3.1413927。

請改正程式中的錯誤,使它能得出正確的結果。註意:部分源程式在文件MODI1.C中,不要改動main函數,不得增行或刪行,也不得更改程式的結構!

試題程式:

#include <stdio.h>
double fun(int n)
{
    double pi = 0.0;
    int i,f=1;
    for (i=1;i<=n;i++)
    {   
/*************found**************/
         pi = pi + f/(2*i-1); 
         f = -f; 
    }
/*************found**************/
    return pi; 
}
int main()
{ 
    printf("PI = %.7lf\n",fun(5000));
    return 0;
}

四、程式設計題(24分)

請編寫函數int fun(int n),其功能是判斷正整數n是否素數,若是返回“1”,否則,返回“0”。所謂素數是指一個大於1的自然數,該數除了1和它本身以外不再有其他的因數。例如,2、3、5、7等數是素數,而4、6、8、9等數不是素數。

註意:部分源程式在文件PROG1.C中。請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括弧中填入你編寫的若幹語句。

試題程式:

#include <stdio.h>
#include <math.h>
int fun(int n)
{


}
int main()
{ 
   int i;
   printf("%4d",2);
   for (i=3;i<100;i=i+2)
       if (fun(i)==1)
           printf("%4d",i);
   printf("\n");
   return 0;
}
一、選擇題
( 1)~(10)  :DCBAB  DADBA
(11)~(20) :CCDCA  CBCDA
(21)~(30) :BBACD  CDBBD
(31)~(40) :DCBBD  ABDAC
二、程式填空題
    (1) char  *
    (2) str+strlen(str)-1
    (3) t==0或 ! t
三、程式改錯題
    (1)  pi = pi + 1.0*f/(2*i-1);
    (2)  return 4*pi;
四、程式設計題
       int i,k;
    k=(int)sqrt(1.0*n);
    for (i=2;i<=k;i++)
        if (n%i==0) break;
    if (i>k)
        return 1;
    else
        return 0;
參考答案:
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 數據也有冷熱之分,你知道嗎? 根據訪問的頻率的高低可將數據分為熱數據和冷數據,訪問頻率高的則為熱數據,低為冷數據。如果熱、冷數據不區分,一併存儲,顯然不科學。將冷數據也存儲在昂貴的記憶體中,那麼你想,成本得多高呢? 有趣的是,根據我們實際的觀察,目前很多使用 Redis 的業務就是這樣操作的。 得益於 ...
  • 這本書去年11月出的,今年中文版也出了,並且直接上了微信讀書,之後有空就讀一讀,分享下讀書筆記~ 原文內容比較充實,建議有時間可以讀一下原文. 第一章主要是個概覽. MySQL的邏輯架構 預設情況下,每個客戶端連接都會在伺服器進程中擁有一個線程,該連接的查詢只會在這個單獨的線程中執行,該線程駐留在一 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 1.uni.getLocation 獲取當前經維度 先上代碼 let that = this // 獲取用戶是否開啟 授權獲取當前的地理位置、速度的許可權。 uni.getSetting({ success (res) { console. ...
  • android studio 升級 Android Studio Dolphin | 2021.3.1 Patch 1後,xml佈局預覽界面報錯 一開始以為是那些警告導致的,有很多黃色的xml警告,比如命名的名字不是英文,或者設置了各種顏色值警告,或者系統要求你添加 contentDescripti ...
  • 面向對象之設計模式 一、設計模式概述 ​ 設計模式(Design Pattern)是前輩們對代碼開發經驗的總結,是解決特定問題的一系列套路。它不是語法規定,而是一套用來提高代碼可復用性、可維護性、穩健性以及安全性的解決方案。 ​ 1995年,GoF(Gang of Four,四人組/四人幫)合作出版 ...
  • 中介模式屬於行為型設計模式,可以將原本難以理解的網狀結構轉換成了相對加單的星型結構,主要用來降低多個對象和類之間的通信複雜性。 ...
  • RAID技術出現的初衷是把多個小容量的硬碟組合起來,以獲得更大的存儲容量。當前我們所說的RAID技術更多則是與數據保護相關,換言之,當物理設備失效時,RAID能夠用來防止數據的丟失。 隨著陣列技術的發展,已經產生了很多不同類型的RAID,但現在只有少數幾種RAID仍在使用。在這個章節中,我們將討論最... ...
  • 面向對象之元類 一、什麼是元類 Python中一切皆為對象,對象是有類實例化生成; 類也是對象(類對象),生成類對象的類可稱之為元類; 所以,元類就是來創建類對象的,可稱之為類工廠; type是python內建元類,type是最上層的元類,也可稱為一切類對象的元類 二、元類推導流程 """推導步驟1 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...