2021-2022年廣東省廣州市全國計算機等級考試C語言程序設計預測試題(含答案)_第1頁
2021-2022年廣東省廣州市全國計算機等級考試C語言程序設計預測試題(含答案)_第2頁
2021-2022年廣東省廣州市全國計算機等級考試C語言程序設計預測試題(含答案)_第3頁
2021-2022年廣東省廣州市全國計算機等級考試C語言程序設計預測試題(含答案)_第4頁
2021-2022年廣東省廣州市全國計算機等級考試C語言程序設計預測試題(含答案)_第5頁
已閱讀5頁,還剩34頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

2021-2022年廣東省廣州市全國計算機等級考試C語言程序設計預測試題(含答案)學校:________班級:________姓名:________考號:________

一、單選題(20題)1.順序查找法適合于存儲結構為()的線性表。

A.散列存儲B.順序存儲或鏈式存儲C.壓縮存儲D.索引存儲

2.現有如下程序段#include"stdio.h"main(){intk[30]={12,324,45,6,768,98,21,34,453,456};intcount=0,i=0;while(k[i]){if(k[i]%2==0||k[i]%5==0)count++;i++;}printf("%d,%d\n",count,i);}則程序段的輸出結果為

A.7,8B.8,8C.7,10D.8,10

3.以下程序的輸出結果是______。#defineM(x,y,z)x*y+zmain(){inta=1,b=2,c=3;printf("%d\n",M(a+b,b+c,c+a));}

A.19B.17C.15D.12

4.可以作為Windows外殼程序的是()

A.程序管理器B.文件管理C.程序管理器和文件管理器D.主群組

5.

6.在所有的排序方法中,關鍵字比較的次數與記錄的初始排列次序無關的是()。

A.希爾排序B.冒泡排序C.直接插入排序D.直接選擇排序

7.若有如下程序:#definePI3.1415926#defineA(r)2*PI*rmain(){floata,1;a=3.0;1=A(a);printf("r=%.2f,1=%.2f\n",a,1);}則程序運行后的輸出結果是()

A.r=3.001=18.85

B.3.00,18.85

C.r=3.0000001=18.8495555

D.r=3.01=18.8495555

8.在Internet中,域名服務器的主要功能是實現()的轉換。

A.IP地址到域名(主機名字)B.域名到IP地址C.主機IP地址和路由器IP地址之間D.路由器IP地址之問

9.下列敘述中正確的是A.為了建立一個關系,首先要構造數據的邏輯關系

B.表示關系的二維表中各元組的每一個分量還可以分成若干數據項

C.一個關系的屬性名表稱為關系模式

D.一個關系可以包括多個二維表

10.下列程序的輸出結果是______。#include<stdio.h>main(){inti,j,k,a=3,b=2;i=(--a==b++)?--a;++b;j=a++;k=b;printf("i=%d,j=%d,k=%d\n",i,j,k);}

A.i=2,j=1,k=3B.i=1,j=1,k=2C.i=4,j=2,k=4D.i=1,j=1,k=3

11.以下定義數組的語句錯誤的是()。

A.intnum[]={1,2,3,4,5,6};

B.intnum[][3]={{1,2},3,4,5,6};

C.intnum[2][4]={{1,2},{3,4},{5,6}};

D.intnum[][4]={1,2,3,4,5,6};

12.字符串"\\"ABCDEF\"\\”的長度是()。

A.11B.10C.5D.3

13.設有定義“intk=0;”,以下選項的4個表達式中與其他3個表達式的值不相同的是()。

A.++kB.k+=1C.k++D.k+1

14.下列描述中正確的是______。

A.軟件工程只是解決軟件項目的管理問題

B.軟件工程主要解決軟件新產品的生產率問題

C.軟件工程的主要思想是強調在軟件開發過程中需要應用工程化原則

D.軟件工程只是解決軟件開發中的技術問題

15.下列敘述中錯誤的是()。A.在數據庫系統中,數據的物理結構必須與邏輯結構一致,

B.數據庫技術的根本目標是要解決數據的共享問題

C.數據庫設計是指在已有數據庫管理系統的基礎上建立數據庫

D.數據庫系統需要操作系統的支持

16.數據結構主要研究的是數據的邏輯結構、數據的運算和()。A.數據的方法B.數據的存儲結構C.數據的對象D.數據的邏輯存儲

17.現有二叉搜索樹(BST)前序遍歷結果序列為abdefgc,中序遍歷結果序列為debgfac,請問后序遍歷結果序列為()

A.debgfaCB.edgfbcAC.edgbfcAD.degbfaC

18.數組A[0...4,-1...-3,5...7]中含有的元素個數是()。A.A.55B.45C.36D.16

19.有以下定義和語句

StructWorkers

{intnum;charname[20];charc;

struct

{intday;intmonth;intyear;}s;

};

StructWorkersW,*pe;

PW=&W;

能給W中yeaR成員賦1980的語句是A.*pW.yeaR=1980;

B.W.yeaR=1980;

C.pW->yeaR=1980;

D.W.s.yeaR=1980;

20.允許對隊列進行的操作有()。

A.對隊列中的元素排序B.取出最近進隊的元素C.在隊頭元素之前插入元素D.刪除隊頭元素

二、2.填空題(20題)21.與表達式a+=b等價的另一書寫形式是______。

22.下述函數通過遞歸方法將字符串倒置,使用時需要指定字符數組的首地址、起始下標和終止下標。請填空:

#include<stdio.h>

voidfun(char*s,intlow,inthigh)

{if(【】)

return;

else

{chart;

fun(【】);

t=s[low];

s[low]=s[high];

s[high]=t;}}

23.在結構化分析方法中,用于描述系統中所用到的全部數據和文件的文檔稱為【】。

24.有以下程序:

#include<stdio.h>

voidf(inty,int*x)

{y=y+*x;*x=*x+y;}

main()

{intx=2,y=4;

f(y,&x);

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

}

執行后的輸出結果【】。

25.以下程序的運行結果是【】。

#include<stdio.h>

#defineMAX(a,b)(a>b?a:b)+1

main()

{inti=6,j=8,k;

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

}

26.以下函數的功能是刪除字符串s中的所有數字字符。請填空。

vioddele(char*s)

{intn=0,i;

for(i=0;s[i];i++)

if(______)

s[n++];s[i];

s[n]=______;

}

27.已知存儲結構如下所示,請填空。

datanext

structlink{chardata;

【】;

}node;

28.數據庫的設計通常可以分為4個步驟:需求分析、概念設計、【】和物理設計。

29.函數fun的功能是計算xn。

doublefun(doublex,intn)

{inti;doubley=1;

for(i=1;i<=n;i++)y=y*x;

returny;

}

主函數中已正確定義m、a、b變量并賦值,并調用fun函數計算:m=a4+b4-(a+b)3。實現這一計算的函數調用語句為【】。

30.以下程序的功能是根據輸入的"y"("Y")與"n"("N"),在屏幕上分別顯示出"ThisisYES."與"ThisisNO."。空白處需要填入的內容是

#include<stdio.h>

voidYesNo(charch)

{switch(ch)

{case′y′:

case′Y′:printf("\nThisisYES.\n");

case′n′:

case′N′:printf("\nThisisNO.\n");}

main()

{charch;

printf("\nEnterachary,Yorn,N:");

ch=【】;

printf("ch;%c",ch);

YesNo(ch);}

31.以下sstrcpy()函數實現字符串復制,即將t所指字符串復制到s所指向內存空間中,形成一個新的字符串s。清填空。

voidsstrcpy(char*s,char*t)

{while(*s++=【】);}

main()

{charstr1[100],str2[]="abcdefgh";

strcpy(str1,str2);

printf('%s\n",str1);

}

32.數據模型按不同應用層次分成3種類型,它們是概念數據模型、【】和物理數據模型。

33.數據流圖的類型有【】和事務型。

34.以下程序可把輸入的十進制數以十六進制數的形式輸出,請填空。

#inelude<stdio.h>

main()

{eharb[17]={"0123456789ABCDEF"};

intc[64],d,i=0,base=16;

longn;

printf("Enteranumber:\n");

seanf("%ld",&n);

do{c[i]=【】;i++;n=n/base;}

while(n!=0);

printf("Transmitenewbase:\n");

for(--i;i>=0;--i)

{d=c[i];printf("%c",b【】);}

printf("\n");

}

35.以下程序從終端讀入數據到數組中,統計其中正數的個數,并計算它們之和。請填空。

main()

{inti,a[20],sum,count;

sum=count=0;

for(i=0;i<20;i++)scanf("%d",【】);

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

{if(a[i]>0)

{count++;

sum+=a[i];

}

}

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

}

36.設有下列宏定義:#defineA2

#defineBA+3

則執行賦值語句;t=B*2;t為int型變量后的值是______。

37.如下圖所示的二叉樹后序遍歷序列是【】。

38.函數rewind的作用是

39.函數count(head)統計鏈表的結點個數,head為表頭指針,閱讀程序,要求將整個if語句改成while循環控制結構,其形式為【】。

#include<stdio.h>

intcount(NODE*head)

{intn=0;

if(head!=NULL)

do

{n++;

head=head->next;

}while(head!=NULL);

returnn;}

40.數據庫系統其內部分為三級模式,即概念模式、內模式和外模式。其中,______是用戶的數據視圖,也就是用戶所見到的數據模式。

三、1.選擇題(20題)41.若int類型數據占兩個字節,則下列語句的輸出結果為()intx=-1;printf("%u\n",x);

A.-1B.32767C.65535D.65536

42.若有定義:“inta[2][3];”,則對a數組的第i行第j列元素的正確引用為()。

A.*(*(a+i)+j)B.(a+i)[j]C.*(a+i+j)D.*(a+i)+j

43.下面的程序輸出結果是()。#defineU5#defineVU+1#defineWV*V/2main(){printf("%d",W);printf("%d",5*W);}

A.1872B.10.552.5C.10.525.5D.1030

44.若指針p已正確定義,要使p指向兩個連續的整型動態存儲單位,不正確的語句是

A.p=2*(int*)malloc(sizeof(int));

B.p=(int*)malloc(2*sizeof(int));

C.p=(int*)malloc(2*2);

D.p=(int*)malloc(2,sizeof(int));

45.若有如下定義:structstu{charname[9];intage;floatscore;);structstuclass[10]={{"Li",17,67},{"Song",19,80},{"guo",18,79},{"Zhao",16,69}};根據上面的定義,若執行“printf("%s:%d%f",class[3].name,class[3].age,class[3].score);"則輸出的正確結果是()。

A.Song:19,80.000000

B.Zhao:16,69.000000

C.Li:17,67Song;19,80

D.guo:18,79Zhao;16,69

46.main(intargc,char*argv[]){while(--argc>0)printf("%s",argv[argc]);printf"\n");}假定以上程序經編譯和連接后生成可執行文件PROG.EXE,如果在此可執行文件所在目錄的DOS提示符下鍵入PROGABCDEFGHIJKL↓,則輸出結果為______。

A.ABCDEFGB.IJHLC.ABCDEFGHIJKLD.IJKLABCDEFGH

47.在C語言中,如果下面的變量都是血類型,則輸出的結果是______。sum=pad=5;pAd=sum++,pad++,++pAd;printf("%d\n",pad);

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

48.設有如下定義:strucksk{inta;floatb;}data;int*p;若要使p指向data中的a域,正確的賦值語句是()。

A.p=&a;B.p=data.a;C.p=&data.a;D.*p=data.a;

49.

若有下列定義(設int類型變量占2個字節):

inti=8,j=9;

則下列語句:

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

輸出的結果是()。

A.i=8,j=9B.i=%d,j=%dC.i=%8,j=%9D.8,9

50.有以下程序#include<stdio.h>main(){FILE*fP;intk,n,a[6]={1,2,3,4,5,6};fp=fopen("d2.dat","w");fprintf(fp,"%d%d%d\n",a[0],a[1],a[2]);fprintf(fp,"%d%d%d\n",a[3],a[4],a[5]);fclose(fp);fp=fopen("d2.dat","r");fscanf(fp,"%d%d",&k,&n);printf("%d%d\n",k,n);fclose(fp);}程序運行后的輸出結果是。

A.12B.14C.1234D.123456

51.下列敘述中正確的是______。

A.數據庫是一個獨立的系統,不需要操作系統的支持

B.數據庫設計是指設計數據庫管理系統

C.數據庫技術的根本目標是要解決數據共享的問題

D.數據庫系統中,數據的物理結構必須與邏輯結構一致

52.執行下面程序的正確結果是()main(){floata=1.9switch(A){case0:printf("0000");case1:printf("1111");case2:printf("3333");}printf("%f",A);}

A.1.900000

B.111133331.900000

C.33331.900000

D.00001111233331.900000

53.下列選項中正確的語句是()。

A.chars[8];s={"Beijing"};

B.char*s:s={Beijing");

C.chars[8]:s="Beijing"};

D.char*s:s="Beijing";

54.有如下函數調用語句func(rec1,rec2+rec3,(rec4,rec5));該函數調用語句中,含有的實參個數是______。

A.3B.4C.5D.有語法錯誤

55.開發軟件所需高成本和產品的低質量之間有著尖銳的矛盾,這種現象稱做()。A.軟件矛盾B.軟件危機C.軟件藕合D.軟件產生

56.有以下程序:#include<stdio.h>main(){intm=3,n=4,x;x=-m++;x=x+8/++n;prinff("%d\n",x);}程序運行后的輸出結果是()。

A.3B.5C.-1D.-2

57.以下程序中函數sort的功能是對a所指數組中的數據進行由大到小的排序voidsort(inta[],intn){inti,j,t;for(i=0;i<n-1;i++)for(j=i+1;j<n;j++)if(a[i]<a[j]){t=a[i];a[i]=a[j];a[j]=t;}}main(){intaa[10]={1,2,3,4,5,6,7,8,9,10},i;sort(&aa[3],5);for(i=0;i<10;i++)printf(“%d”,aa[i]);pfintf(“\n”);}程序運行后的輸出結果是

A.1,2,3,4,5,6,7,8,9,10

B.10,9,8:7,6,5,4,3,2,1

C.1,2,3,8,7,6,5,4,9,10

D.1,2,10,9,8,7,6,5,4,3

58.為了使模塊盡可能獨立,要求()。

A.內聚程度要盡量高,耦臺程度要盡量強

B.內聚程度要盡量高,耦合程度要盡量弱

C.內聚程度要盡量低,耦合程度要盡量弱

D.內聚程度要盡量低,耦合程度要盡最強

59.在數據庫設計中,將E-R圖轉換成關系數據模型的過程屬于()A.需求分析階段B.邏輯設計階段C.概念設計階段D.物理設計階段

60.下列敘述中,不屬于軟件需求規格說明書的作用的是()

A.便于用戶,開發人員進行理解和交流

B.反映出用戶問題的結構,可以作為軟件開發工作的基礎和依據

C.作為確認測試和驗收的依據

D.便于開發人員進行需求分析

四、選擇題(20題)61.

62.從循環體內某一層跳出,繼續執行循環外的語句是:___________。

A.break語句B.return語句C.continue語句D.空語句。

63.若有定義:則以下不能正確表示該數組元素的表達式是()。

64.

A.P=8;B.P=k;C.P=s[0];D.k=s;

65.設有定義

66.

67.

有以下程序

#include<stdio.h>

#include<string.h>

typedefstrlIct{charname[9];charsex;floatscore[2];}STU;

STUf(STUa)

{STUb={"Zhao",m,85.0,90.0);inti;

strcpy(aname,b.name);

sex:b.sex;

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

returna;

}

main

{STUc="Qian",f,95.0,92.0},d;

d=f(c).printf("%s,%c,%2.0f,%2.0f",d.Name,d.sex,d.score[0],d.score[1]);

}

程序的運行結果是()。

A.Qian,f,95,92

B.Qian,m,85,90

C.Zhao,m,85,90

D.Zhao,f,95,92

68.結構化程序所要求的基本結構不包括()。

A.順序結構B.選擇(分支)結構C.GOT0跳轉D.重復(循環)結構

69.計算機的內存儲器比外存器()

A.價格便宜B.存儲容量大C.讀寫速度快D.讀寫速度慢

70.軟件設計中衡量模塊獨立性的度量標準是()。

A.抽象和信息隱蔽B.局部化和封裝化C.內聚性和耦合性D.激活機制和控制方法

71.設有定義:intX=2;,以下表達式中,值不為6的是()。

A.2*x.x+=2B.x++,2*xC.x*=(1+x)D.x*!x+1

72.

下列程序的運行結果是()。

inty=5,x=14;

y=((x=3*Y,x+1),x-1);

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

A.x=27,y=27B.x=12,y=13C.x=15,y=14D.x=y=27

73.

有以下程序:

#include<stdio.h>

voidfun(char*t,char*s)

{while(*t!=O)t++;

while((*t++=*s++)!=0);

}

main

{charss[10]="acc",aa[10]="bbxxyy";

fun(ss,aa);printf("%S,%s",ss,aa);

}

程序運行結果是()。

A.accxyy,bbxxyy

B.ace,bbxxyy

C.accxxyy,bbxxyy

D.accbbxxyy,bbxxyy

74.下列敘述中正確的是()。

A.線性表的鏈式存儲結構與順序存儲結構所需要的存儲空間是相同的

B.線性表的鏈式存儲結構所需要的存儲空間一般要多于順序存儲結構

C.線性表的鏈式存儲結構所需要的存儲空間一般要少于順序存儲結構

D.線性表的鏈式存儲結構所需要的存儲空間與順序存儲結構沒有任何關系

75.在軟件開發中,需求分析階段產生的主要文檔是()。A.軟件集成測試計劃B.軟件詳細設計說明書C.用戶手冊D.軟件需求規格說明書

76.

77.下列關于棧的敘述中,正確的是()。

A.棧底元素一定是最后入棧的元素B.棧操作遵循先進后出的原則C.棧頂元素一定是最先入棧的元素D.以上三種說法都不對

78.最簡單的交換排序方法是()。A.快速排序B.選擇排序C.堆排序D.冒泡排序

79.

80.有定義語句:“int*p[4];”,以下選項中與此語句等價的是()。

A.intp[4];B.int**P;C.int*(p[4]);D.int(*p)[4];

五、程序改錯題(1題)81.下列給定程序中,函數proc的功能是計算正整數m各位上數字的平方和。 例如,輸入498,則輸出應該是161。 請修改程序中的錯誤,使它能得到正確結果。 注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。 試題程序: #include<stdlib.h> #include<stdio.h> #include<conio.h> longproc(10ngm) {//****found****longsum=1;do{sum+=(m%10)*(m%10);m/=l0;//****found****}while(m)return(sum); } voidmain {longn;system("CLS");printf("Pleaseenteranumber:");scanf("%1d",&n);printf("\n%ld\n",proc(n)); }

六、程序設計題(1題)82.使用VC++2010打開考生文件夾下prog1中的解決方案。此解決方案的項目中包含一個源程序文件prog1.c。在此程序中,請編寫函數fun(),其功能是將M行N列的二維數組中的數據,按列的順序依次存放到一維數組中,將一維數組中數據的個數存放在形參n所指的存儲單元中。注意:部分源程序給出如下。請勿改動主函數main()和其他函數中的任何內容,僅在函數fun()的花括號中填入你編寫的若干語句。試題程序:#include<stdio.h>voidfun(int(*s)[10],int*b,int*n,intmm,intnn){}main(){intw[10][10]={{33,33,33,33},{44,44,44,44},{55,55,55,55}},i,j;inta[100]={0},n=0;printf(“Thematrix:\n”);for(i=0;i<3;i++){for(j=0;j<4;j++)printf(“%3d”,w[i][j]);printf(“\n”);}fun(w,a,&n,3,4);printf(“TheAarray:\n”);for(i=0;i<n;i++)<p=""></n;i++)<>printf(“%3d”,a[i]);}

參考答案

1.B

2.D解析:在C語言中,定義一維數組的語句一般形式如下:

類型名數組名[常量表達式];

一維數組的引用形式為:數組名[下標表達式]。count表示能被2整除或被5整除的個數,i則計算有多少個數組元素。

3.D解析:C語言的宏定義包括不帶參數的宏定義與帶參數的宏定義。本題為帶參數的宏定義,其形式為:

#define宏名(形參表)字符串

本題的M(a+b,b+c,c+a)被字符串a+b*b+c+c+a代替。

4.C

5.A

6.D

7.A

8.B在Internet中,把域名翻譯為IP地址的軟件稱為域名系統DNS,運行域名系統的主機稱為域名服務器。域名服務器的主要功能是實現入網主機名字和IP地址的轉換。

9.C解析:在格式化模型中,要事先根據應用的需要,確定數據之間的邏輯關系,即先對數據進行結構化。在關系模型中,不需要事先構造數據的邏輯關系,只要將數據按照一定的關系存入計算機,也就是建立關系。所以選項A錯誤。對于一個表示關系的二維表,其最基本的要求是表中元組的每一個分量必須是不可分的數據項,即不允許表中再有表。所以,選項B、D說法是錯誤的。一個關系的屬性名表稱為關系模式,也就是二維表的表框架,相當于記錄型。因此,選項C說法正確。

10.D

11.B二維數組的定義有3種形式,第一種是分行為兩位數組賦值,即intnum[]={{12},{3,4},{5,6}},第二種是按照數組排列順序進行賦值,即intnum[]={1,2,3,4,5,6},第三種為對部分元素賦初值,即intnum[]={{1,2}{},{3,4},{5,6}},所以錯誤的為B。

12.B解析:本題涉及字符串的兩個最基本的概念。①字符串的長度是指字符串中字符的個數,但不包含字符串結束符;②以反斜線“\\”開頭的特殊字符序列,意思是把反斜線后面的字符序列轉換成特定的含義,而不是原來的含義,不包含在字符串長度之內,“\\”連同后面的字符為一個長度。

13.C表達式“++k”是先使得k的值自增1后再使用。表達式“k++”是先取得k的值再將k的值自增1。所以C選項中表達式的值為0,而其他3個選項中表達式的值均為1。故本題答案為C選項。

14.C解析:軟件工程是解決軟件項目的管理、軟件開發過程中的技術、軟件產品的生產率等問題,它的主要思想是強調在軟件開發過程中需要應用工程化原則。

15.A解析:本題考查數據庫系統的基本概念和知識。數據的邏輯結構,是數據間關系的描述,它只抽象地反映數據元素之間的邏輯關系,而不管其在計算機中的存儲方式。數據的存儲結構,又叫物理結構,是邏輯結構在計算機存儲器里的實現。這兩者之間沒有必然的聯系。因此,選項A的說法是錯誤的。

數據庫可以看成是長期存儲在計算機內的、大量的、有結構的和可共享的數據集合。因此,數據庫具有為各種用戶所共享的特點。不同的用戶可以使用同一個數據庫,可以取出它們所需要的子集,而且容許子集任意重疊。數據庫的根本目標是要解決數據的共享問題。因此,選項B的說法是正確的。

數據庫設計是在數據庫管理系統的支持下,按照應用的要求,設計一個結構合理、使用方便、效率較高的數據庫及其應用系統。數據庫設計包含兩方面的內容:一是結構設計,也就是設計數據庫框架或數據庫結構;二是行為設計,即設計基于數據庫的各類應用程序、事務等。因此,選項C的說法是錯誤的。

數據庫系統除了數據庫管理軟件之外,還必須有其他相關軟件的支持。這些軟件包括操作系統、編譯系統、應用軟件開發工具等。對于大型的多用戶數據庫系統和網絡數據庫系統,還需要多用戶系統軟件和網絡系統軟件的支持。因此,選項D的說法是正確的。因此,本題的正確答案是選項A。

16.B詳細解答:

數據結構是研究數據元素及其之間的相互關系和數據運算的一門學科,它包含3個方面的內容,即數據的邏輯結構、存儲結構和數據的運算。

17.B

18.A

19.D解析:結構體structureworkers中的成員s是結構體類型,給w中成員year賦值的語句是w.s.year=1980,故選D。

20.D

21.a=a+ba=a+b解析:a+=b與a=a+b等價,作用是把變量a的值加b后再賦給變量a。

22.low>=highscow+1high-1low>=high\r\ns,cow+1,high-1解析:本題考查了用指針引用一維數組元素的方法。函數fun()通過遞歸調用的方式將字符串的首位和末位互換,第二位和倒數第二位互換……,從而實現了字符串倒置的功能。low和high是字符數組的下標。

23.數據字典數據字典解析:在結構化分析方法中,用于描述系統中所用到的全部數據和文件的文檔稱為數據字典。

24.8484解析:f函數中變量x傳的是變量的地址,而變量y是傳的值,調用函數f后,雖然f函數中的。x變為8,y值也變了,但main函數中的y未變,仍然為4。

25.99解析:本題考查宏定義與三目運算符的綜合應用。宏定義是原樣替換,本題中,如果a>b成立,則a+1的值為整個表達式的值,否則b+1的值為整個表達式的值(應注意后面的加1)。

26.s[i]<'0'‖s[i]>9或!(s[i]>='0'&&s[i]<='9')或!(isdigit(s[i]))isdigit(s[i])==0或s[i]>'9'‖s[i>'0'或!(s[i]<='9'&&s[i]>='0')或*(s+i)<'0'‖*(s+i)>'9'或!(*(s+i)>='0'&&*(s+i)<=9或!(isdigit(*(s+i)))或*(s+i)>='9'&&*(s+i)<='0'!(*(s+i)<='9'&&*(s+i)>='0'或iss[i]<'0'‖s[i]>9,或\r\n!(s[i]>='0'&&s[i]<='9')或!(isdigit(s[i]))\r\nisdigit(s[i])==0或s[i]>'9'‖s[i>'0'或\r\n!(s[i]<='9'&&s[i]>='0')或*(s+i)<'0'‖*(s+i)>'9'或\r\n!(*(s+i)>='0'&&*(s+i)<=9或!(isdigit(*(s+i)))或\r\n*(s+i)>='9'&&*(s+i)<='0'\r\n!(*(s+i)<='9'&&*(s+i)>='0'或is解析:本題考核的知識點是字符指針變量作為函數的參數以及與字符串有關的算法。從一個字符串中刪除某字符的方法是從字符串的第一個字符開始一一判斷該字符是否是要刪除的字符,若不是則把它放到結果字符串中,若是則不放入結果字符串中。本題的第一個空應判斷a[i]是否為數字字符,只有在不是數字字符的情況下才存入結果字符串,所以應填入s[i]<'0'‖s[i]>'9'。最后應在結果字符串的末尾填上字符串結束標志“\\0”。

27.strucklink*nextstrucklink*next解析:結構體變量構成鏈表要求結構體中必須有一個指向該結構體變量自身的指針用來指明鏈表的下一個結點。注意:結構體變量的定義及其成員變量的引用。

28.邏輯設計邏輯設計解析:數據庫設計的4個階段為:需求分析、概念設計、邏輯設計和物理設計。

29.m=fun(a4)+fun(b4)-fun(a+b3);m=fun(a,4)+fun(b,4)-fun(a+b,3);解析:函數fun(x,n)的作用是求xn,因此a4應該調用函數fun(a,4),b4應該調用函數fun(b,4),(a+b)3應該調用函數fun(a+b,3),所以題目中的數學表達式,寫成C程序中的語句為m=fun(a,4)+fun(b,4)-fun(a+b,3)。

30.getchargetchar解析:考查了字符可以作為整型變量來對待,參與操作。題中要求根據輸入的字符調用函數YesNo來判斷輸入的字符是y(Y)還是n(N),字符的輸入可用字符輸入函數getchar。函數YesNo用來判斷一個字符是y(Y)還是n(N),主要用了一個switch多分支結構來比較輸入字符與字符\ue008'y',\ue009'Y'、,'n','N'是否相等來實現的。

31.*t++或*(t++)*t++或*(t++)解析:主函數中定義了兩個字符型數組str1和str2,并且給str2賦初值“abcdefgh”,接著調用函數strcpy(str1,str2),將字符串str2的值賦給str1。在函數sstrcpy(*s,*t)中,用了一個while循環,每循環一次將形參指針t所指的字符賦給形參指針s所指向的存儲空間,然后將指針s和t都移到下一個元素。所以空白處應該填*t++或*(t++)。

32.邏輯數據模型邏輯數據模型解析:數據是現實世界符號的抽象,而數據模型(datamodel)則是數據特征的抽象,它從抽象層次上描述了系統的靜態特征、動態行為和約束行為,為數據庫系統的信息表示與操作提供一個抽象的框架。數據模型按不同的應用層次分成3種類型,它們是概念數據模型(conceptualdatamodel)、邏輯數據模型(logicdatamodel)、物理數據模型(physicaldatamodel)。

33.變換型典型的數據流類型有兩種:變換型和事務型。變換型是指信息沿輸入通路進入系統,同時由外部形式變換成內部形式,進入系統的信息通過變換中心,經加工處理以后再沿輸出通路變換成外部形式離開軟件系統;在很多軟件應用中,存在某種作業數據流,它可以引發一個或多個處理,這些處理能夠完成該作業要求的功能,這種數據流就叫做事務。

34.n%base[d]n%base[d]解析:程序中的字符數組b存儲了十六進制16個數字的字符,整型數組c用于存儲轉換的十六進制數的各位數值。將整數n轉換成它的各位十六進制數值,需采用除以16取余的方法,即求n除以16的余,得到它的十六進制的末位數,接著將n除以16,在n不等于0的情況下循環,順序求出n的十六進制的倒數第一、第二、第三位數等。程序中變量base已預置16,所以在第一處填n%base。當n的十六進制數的倒數第一、第二、第三位等依次存放于數組c中后,就從最高位至最低位,參照數組c[i]的內容d(以其內容為下標),取十六進制數字符表中的字符b[d)輸出,所以在第二處填[d]。

35.&a[i]&a[i]解析:主要考查函數scanf的用法.應填數組a的元素的地址。

36.88解析:本題考查帶參數的宏定義及相關運算.運算過程為:t=B*2=A+3*2=2+3*2=8。

37.GDBHIEFCAGDBHIEFCA解析:后序遍歷二叉樹的順序為:后序遍歷左子樹→后序遍歷右子樹→訪問根結點。按照定義,后序遍歷序列是GDBHIEFCA。

38.A

39.while(p!=NULL){n++;head=head→next;}while(p!=NULL){n++;head=head→next;}解析:do…while循環轉化為while循環,循環體執行的內容應該是一致的,不同的是do…while結構是先執行一次循環體,然后再判斷循環條件是否滿足,而while循環則是先判斷循環條件是否滿足,滿足則執行循環體。所以do…while循環結構若想轉換為while循環結構,必須在do…while循環之前先對循環條件進行一個判斷,即此題中的if(head!=NULL)。注意:3種循環結構的比較。

40.外模式外模式解析:數據庫系統的三級模式分別是內模式、概念模式和外模式。其中,物理模式給出了數據庫的物理存儲結構和存取方法;概念模式是數據庫系統中全局數據邏輯結構的描述;外模式是用戶的數據視圖,也就是用戶所見到的數據模式。

41.C

42.A解析:本題考查如何通過地址來引用數組元素。通過地址來引用數組元素的方法有下列5種:

①a[i][j];②*(a[i]+j);③*(*(a+i)+j);④*(a[i])[j];⑤*(&a[0][0]+3*i+j)。

43.D解析:宏W展開后為V*V/2,繼續展開為U+1*U+1/2,再繼續展開得5+1*5+1/2=5+5+0=10。而5*W展開后為5*5+1*5+1/2=25+5+0=30。故應該選擇D。

44.A解析:malloc()函數的調用格式是“malloc(n)”,作用是申請n個字符的存儲單元并把該存儲區的首地址作為返回值,實際調用的時候可在前面加上“(類型說明符*)”,以轉換成需要的類型的地址。選項D多了一個參數,不符合malloc()函數的調用格式;整型變量在有的計算機系統里占4個字節,并不一定在所有的計算機系統里都是兩個字節;選項A中是申請一個整型的存儲空間并把該存儲空間的首地址乘以2,這樣的做法是不正確的,其存儲空間為沒乘以2之前的存儲空間的2倍的連續存儲空間的地址。

45.B解析:class[10]是結構體型的數組,class[3]為{'Zhao',16,69}。

46.C解析:本題主函數帶有兩個參數,一個int型變量argc,另一個是char型的一維一級指針數組argv。當主函數被執行時,系統自動將根據命令行的情況,分別給主函數的兩個參數賦值。Argc中存放命令行中命令字和參數的總和的個數,argv用來存放命令行中命令字和所有參數的字符串的,并規定argv[0]存放命令字字符串,argv[1]用來存放第一個參數的字符串,argv[2]用來存放第2個參數的字符串,依此類推。題中argc的值是2,執行完-argc后為1,輸出argv[1],此數組存在第一個參數的字符串ABCDEFGHIJKL。

47.C

48.C解析:data是一結構體變量,a是它的成員,因此引用a域的正確方法是:data.a,取它的地址賦值給指針變量p的語句應該是:p=&data.a。選項A將a的地址直接賦給了p,而忽略了a為結構體內部的一個成員,不是一單獨的變量,故選項A不正確;選項B在p=data.a表達式中右邊為一個結構體變量的成員不是地址,而左邊為一指針應該將一地址賦給它,故選項B不正確。選項D表達式*p=data.a是將結構體變量中的成員a的值賦給指針p所指向的變量值,而不是使指針p指向data中的a域,故選項D不正確。

49.B解析:本題考查printf函數的格式。在printf函數中,如果格式說明符中有兩個%說明,則將第1個%后面的字符原樣輸出,并不輸出其對應的變量值。

50.D解析:將有6個元素的整型數組分兩行輸出到一個文件中,因為輸出的都是數字并且每行都沒有分隔符,所以當再對其進行讀取操作時,每一行都會被認為是一個完整的數,而換行符則作為它們的分隔符。

51.C解析:數據庫不是一個獨立的系統,它需要操作系統的支持,選項A錯誤;設計數據庫的目的是設計出滿足實際應用需求的實際關系模型,選項B錯誤;數據庫技術的主要目的是有效地管理和存取大量的數據資源,包括:提高數據的共享性,使多個用戶能夠同時訪問數據庫中的數據;減小數據的冗余,以提高數據的一致性和完整性;提供數據與應用程序的獨立性,從而減少應用程序的開發和維護代價,選項C正確。數據庫系統中,數據的物理結構和邏輯結構可以相互獨立,選項D錯誤。

52.B

53.D解析:寧符數組初始化可以有兩種方式:方式一,按單個字符的方式賦初值。方式二,把一個字符串作為初值賦給字符數組。比如:charch[5]={'abc'),選項A屬于這種情況,但是選項A定義的字符數組長度為8,由于最后還要加一個“\\0”做結束標志,所以賦給他的字符串長度應小于等于7,所以選項A不正確;在給字符數組賦初值的時候,應該用花括號“{”和“}”將字符串括起來,故選項C不正確。將字符型指針變量指向字符串也有兩種方法,一是在定義指針變量時就給其賦初值,比如:char*p='student'二是給指針變量賦值,比如:p='student';(p已經被定義為字符型指針變量:),故選項D正確,而選項C中的花括號是多余的,應該去掉,所以,4個選項中選項D符合題意。

54.A解析:(rec4,rec5)是逗號表達式,它的值是rec5的值。所以該函數調用語句含有的實參個數是3。

55.BB)【解析】隨著計算機軟件規模的擴大,軟件本身的復雜性不斷增加,研制周期顯著變長,正確性難以保證,軟件開發費用上漲,生產效率急劇下降,從而出現了入們難以控制軟件發展的局面,即所謂的“軟件危機”。

56.D解析:程序中x=-m++執行后x=-3,執行x=x+8/++n相當于執行x=-3+8/5,即n先增加1,再代入表達式運算,結果為-2。

57.C解析:本題中首先定義一個長度為10的一個整型數組,并初始化為“l,2,3,4,5,6,7,8,9,10”,然后調用排序函數sort(),通過分析不難看出,sort()函數是對具有n個元素的a數組進行從大到小排序。由于函數的第一個參數是數組名,其對應的實參可以是函數名或地址。本題在調用該函數時,實參是&aa[3]的地址,即把aa[3]的地址傳給了形參數組名a,函數也就是對aa[3]開始的5個元素進行從大到小的排序,aa[0]、aa[1]、aa[2]、aa[8]、aa[9]并沒有變化。sort()執行完畢后,接著執行后面的for語句輸出數組aa中各個元素的值,由于函數sort()只是對aa[3]開始的5個元素進行從大到小的排序,aa[0]、aa[1]、aa[2]、aa[8]、aa[9]并沒有變化,所以輸出為“1,2,3,8,7,6,5,4,9,10”。

58.B

59.B數據庫應用系統的邏輯設計包括數據庫邏輯結構設計、數據庫事務概要設計和應用程序概要設計三方面。數據庫邏輯結構設計的主要步驟為:將E—R圖轉換為初始關系模式,對初始關系模式進行優化,檢查關系表對數據庫事務的支持性,確定關系模式完整性約束,設計基于關系模式的用戶視圖。

60.D解析:軟件需求規格說明書SRS,SoftwareRequirementSpecification)是需求分析階段的最后成果,是軟件開發中的重要文檔之一。它有以下幾個方面的作用,①便于用戶、開發人員進行理解和交流;②反映出用戶問題的結構,可以作為軟件開發工作的基礎和依據;③作為確認測試和驗收的依據。

61.D

62.A

63.A本題考查的是通過指針引用二維數組元素。通過一維數組名或指向一維數組元素的指針來引用數組元素有兩種寫法:a[i]和*(a+i),它們是等價的。這是一種運算符之間的等價轉換,就好像a一(b—c)等價于a-b+c一樣。知道

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論