06年4月全國計算機等級考試二級C語言考前密卷3

字號:

二、填空題(每空2分,共40分)
    請將每一個空的正確答案寫在答題卡的【1】至【20】序號的橫線上,答在試卷上不得  分。
    (1)算法的復雜度主要包括時間復雜度和 【1】 復雜度。
    答案:【1】空間
    評析:習慣上常常把語句重復執(zhí)行的次數(shù)作為算法運行時間的相對量度,稱作算法的時間復雜度。算法在運行過程中需輔助存儲空間的大小稱為算法的空間復雜度。   
    (2)數(shù)據(jù)的物理結(jié)構(gòu)在計算機存儲空間中的存放形式稱為數(shù)據(jù)的 【2】 。
    答案:【2】內(nèi)模式或物理模式或存儲模式
    評析:一個數(shù)據(jù)庫只有一個內(nèi)模式,它是數(shù)據(jù)物理結(jié)構(gòu)和存儲方式的描述,是數(shù)據(jù)庫內(nèi)部的表示方法。例如,記錄的存儲方式是順序存儲、索引按照什么方式組織;數(shù)據(jù)是否壓縮存儲,是否加密等。
    (3)若按功能劃分,軟件測試的方法通常分為 【3】 測試方法和黑盒測試方法。
    答案:【3】白盒
    評析:軟件測試的方法有三種:動態(tài)測試、靜態(tài)測試和正確性證明。設(shè)計測試實例的方法一般有兩類:黑盒測試方法和自盒測試方法。
    (4)數(shù)據(jù)庫三級模式體系結(jié)構(gòu)的劃分,有利于保持數(shù)據(jù)庫的 【4】 。
    答案:【4】數(shù)據(jù)獨立性
    評析:數(shù)據(jù)庫的三級模式體系結(jié)構(gòu)把數(shù)據(jù)的組織管理工作進行了劃分,把數(shù)據(jù)的具體組織留給dbms管理,使用戶能邏輯地、抽象地處理數(shù)據(jù),而不必關(guān)心數(shù)據(jù)在計算機中的具體表示方式與存儲方式,保證了數(shù)據(jù)的獨立性。
    (5)在關(guān)系運算中,查找滿足一定條件的元組的運算稱之為 【5】 。
    答案:【5】選擇
    評析:在關(guān)系數(shù)據(jù)庫中,選擇運算也是一個元運算,關(guān)系r通過選擇運算(并由該運算給出所選擇的邏輯條件)后仍為一個關(guān)系。這個關(guān)系是由r中的那些滿足邏輯條件的元組所組成。
    (6)在c語言中(以16位pc機為例),一個float型數(shù)據(jù)在內(nèi)存中所占的字節(jié)數(shù)為4;一個double型數(shù)據(jù)在內(nèi)存中所占的字節(jié)數(shù)為 【6】 。
    答案:【6】8
    評析:在一般16位pc機中,一個float型數(shù)據(jù)在內(nèi)存中占4個字節(jié)(32位),一個double型數(shù)據(jù)占8個字節(jié)。
    (7)設(shè)有以下變量定義,并已賦確定的值,
    char w;int x;float y;double z;
    則表達式:w*x+z-y所求得的數(shù)據(jù)類型為 【7】 。
    答案:【7】double型或雙精度型
    評析:①先進行w*x的運算,先將字符型w轉(zhuǎn)換成整型,運算結(jié)果為整型;②再將w*x的結(jié)果與z相加,要先將第一步的整型轉(zhuǎn)換為double型,運算結(jié)果為double型;③最后將w*x+z的結(jié)果與y相減,要先將float型y轉(zhuǎn)換成double型,結(jié)果為double型。
    (8)若運行時給變量x輸入12,則以下程序的運行結(jié)果是 【8】?。?BR>    main(){
    int,y;
    scanf(""%d"",&x);
    y=x>12?x+lo:x-12;
    printf(""%d\n"",y);
    }
    答案:【8】0
    評析:三目運算符的形式為(表達式1)7(表達式2):(表達式3)。當(表達式1)值為真時,返回(表達式2)的值;為假時,返回(表達式3)的值。題中因為x>t2為假,所以結(jié)果為x-12,即為0。(9)四條語句:x++;、++x;、x=x+l;、x=l+x;,執(zhí)行后都使變量x中的值增l,請寫出一條同一功能的賦值語句(不得與列舉的相同) 【9】 。
    答案:【9】x+=1:
    評析:題面中的四條語句的作用是使x的值加1,在c中有多種方法可以對變量進行加1操作,這里可以利用c的復合賦值運算符+=實現(xiàn),本題答案為x+=1:。
    (10)設(shè)有以下定義和語句,則*(*(p+2)+1)的值為 【10】 。
    int[3][2]={10,20,30,40,50,60},(*p)[2];
    p=a;
    答案:【10】60
    評析:本題定義了一個3行2列的二維數(shù)組a,并定義了一個指向兩個元素的一維數(shù)組指針p,讓p指向二維數(shù)組a的首行。*(*(p+2)+1)是引用a[2][1],其值是60。
    (11)若要使指針p指向一個double類型的動態(tài)存儲單元,請?zhí)羁铡?BR>    p= 【11】 malloc(sizeof(double));
    答案:【11】(double*)
    評析:函數(shù)malloc返回的是void*,所以若要使指針指向一個double類型,則必須進行類型轉(zhuǎn)換,類型轉(zhuǎn)換格式為:(數(shù)據(jù)類型*)。
    (12)下面程序的功能:輸出100以內(nèi)能被3整除且個位數(shù)為6的所有整數(shù),請補充完整。
    main().
    { int ij;
    for(i=o; 【12】?。籭++)
    { j=i*10+6;
    if( 【13】 )continue;
    printf("%d",j);
    }
    }
    答案:【12】i    【13】j%3!=0
    評析:本題要求輸出100以內(nèi)能被3整除且個位數(shù)為6的所有整數(shù),程序中j=i*10+6;語句是求個位數(shù)為6的整數(shù),由此可得出程序的循環(huán)次數(shù)為i    (13)函數(shù)mycmp(char*s,char。t)的功能是比較字符串s和t的大小,當s等于t時返回0,
    當s>t返回正值,當s    mycmp(char*s,char*t)
    { while(*s==*t)
    { if(*s==’\0’)return 0;
    ++s;++t;
    }
    return( 【14】 );
    }
    答案:【14】*s-*t或-*t+*s
    評析:函數(shù)的兩個形參是兩個字符指針變量,字符串的首地址是指針變量的值,*s和*t表示字符串數(shù)組s和t的第一個字符,在while循環(huán)中,是通過s和t值的不斷變化來改變指針所指向的字符,要改變s和t所指不同字符的ascii碼的差值,必須使用"*s-*t"得出。
    (14)以下程序運行后的輸出結(jié)果是 【15】 。
    void fun(、)
    {
    static int a=0:
    a+=2;printf("%d",a);
    }
    main()
    { int cc;
    for(cc=1;cc<4;cc++)fun();
    printf("\n");
    }
    答案:【15】2 4 6
    評析:static聲明的外部變量只限于被本文件引用,而不能被其他文件引用。用static來聲明一個變量的作用有:①對局部變量用static聲明,則為該變量分配的空間在整個程序執(zhí)行期間始終存在;②全部變量用static聲明,則該變量的作用域只限于本文件模塊(即被聲明的文件中)。
    (15)下列程序的運行結(jié)果是 【16】 。
    main()
    { union example
    { struct
    {int x;int y;}in;
    int a;
    int b:
    }e;
    e.a(chǎn)=1;e.b=2;
    e.in.x=e.a(chǎn)*e.b;
    e.in.y=e.a(chǎn)+e.b;
    printf("%d,%d\n",e.in.x,e.in.y);
    }
    答案:【16】4,8
    評析:c語言規(guī)定,共用體中各個成員變量在內(nèi)存中占用同一段內(nèi)存單元,即e.in.x和e.a(chǎn)、e.b占用同一段內(nèi)存單元,由于e.in.x和e.a(chǎn)、e.b占用的是同一段內(nèi)存單元,所以程序最后的打印結(jié)果為"4,8"。 (16)在對文件進行操作的過程中,若要求文件的位置回到文件的開頭,應當調(diào)用的函數(shù)  是 【17】 函數(shù)。
    答案:【17】[nnlrewind或fseek
    評析:在對文件進行操作的過程中,若要求文件的位置回到文件的開頭,可以調(diào)用rewind或fseek函數(shù)。其中rewind函數(shù)的作用是將位置指針重新返回文件的開頭,而fseek函數(shù)可以實現(xiàn)文件指針的定位。
    (17)以下函數(shù)用于求出一個2×4矩陣中的元素值。
    max_value(arr)
    int arr[][4];
    {
    int i,j,max;
    max=alt[0][0];
    for(i=0;i<2;i++)
    for(j=0; 【18】 ;j++)
    if( 【19】 >max)max=[2q];
    return(max);
    }
    答案:【18】j<4
    【19】arr[i][j]
    【20】arr[i][j]
    評析:2*4矩陣實際上就是一個二維數(shù)組,結(jié)合本題應為arr[2][4],所以在第一個循環(huán)中應當填寫"4";第二個橫線處是要判斷當前的數(shù)組元素值是否大于max,所以應填寫arr[i][j];第三個橫線處是要將當前大于max的數(shù)組元素的值賦給變量max,所以應當填寫"arr[i][il"。