2017年計算機二級C語言考前試題及答案6

字號:


    二、程序填空題(共18分)、
    下列給定程序中,函數(shù)flm的功能是:將s所指字符串中的所有數(shù)字字符移到所有非數(shù)字字符之后,并保持數(shù)字字符串和非數(shù)字字符串原有的次序。
    例如,s所指的字符串為“def35adh3kjsdt7”,執(zhí)行后結(jié)果為“defadhajsdt3537”。
    請在程序的下劃線處填入正確的內(nèi)容并將下劃線刪除,使程序得出正確的結(jié)果。注意:部分源程序在文件BLANKl.c中。
    不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
    
    三、程序修改題(共l8分)
    下列給定程序中函數(shù)fun的功能是:用冒泡法對6個字符串進行升序排列。請改正程序中的錯誤,使它能得出正確的結(jié)果。
    注意:部分源程序在文件MODIl.C中,不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
    
    
    四、程序設(shè)計題(共24分)
    編寫函數(shù)fun,其功能是:求ss所指字符串中指定字符的個數(shù),并返回此值。例如,若輸入字符串123412132,輸入字符為l,則輸出3。
    注意:部分源程序在文件PROCl.C中。
    請勿改動主函數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號中填人你編寫的若干語句。
    
    二、程序填空題
    【參考答案】
    (1)j++或j+=1或++j或j=j+1
    (2)s[i]=t1[i](3)j
    【考點分析】
    本題考查:指針型變量;數(shù)組變量賦值;for循環(huán)語句。
    【解題思路】
    填空1:根據(jù)函致fun中的內(nèi)容可知,數(shù)組t1存儲了s中的非數(shù)字字符,數(shù)組口存儲了s中的數(shù)字字符,為了存儲下一個數(shù)字字符,下標j要進行加1操作。
    填空2:將S串中的數(shù)字與非數(shù)字字符分開后,要先將非數(shù)字字符放入字符串s中,因此填入s[i]=t1[i]。
    填空3:最后將敦字字符加到s串之后,并且i要小于數(shù)字的個數(shù)j。
    三、程序修改題
    【參考答案】
    (1)fh(j=i+1;j<6;j++)
    (2)*(pstr+i)=}(pstr+j);
    【考點分析】
    本題考查:冒泡排序算法;for循環(huán)語句格式;指針數(shù)組。
    【解題思路】
    (1)此處考查for語句的格式,各表達式之間應用“;”隔開。
    (2)此處考查用指針表示數(shù)組元素的方法,}(pstr+I)表示pstr所指向數(shù)組的第1個元素,同理}(pstr+j)表示pstr所指向數(shù)組的第j個元素。
    【解題寶典】
    冒泡排序算法,其基本思想是,將待排序的元素看作是豎著排列的“氣泡”,較小的元素比較輕,從而要往上浮。在冒泡排序算法中我們要對這個“氣泡”序列處理若干遍。所謂一遍處理,就是自底向上檢查一遍這個序列,并時刻注意兩個相鄰的元素的順序是否正確。如果發(fā)現(xiàn)兩個相鄰元素的順序不對,即“輕”的元素在下面,就交換它們的位置。顯然,處理一遍之后,“最輕”的元素就浮到了位置;處理二遍之后,“次輕”的元素就浮到了次高位置。依次類推,完成排序。
    用代碼實現(xiàn)數(shù)組s[N]的升序排列為:for(i=0;i
    for(j=i十1;j
    if(s[i]>s[j]){t-s[i];s[i]=s[j]s[j]=t;}
    四、程序設(shè)計題【參考答案】int fun(char*ss,char c)
    inti=0;
    for(;*ss!=’\0‘;ss++)if(}ss==c
    i++/*求出*所指字符串中指定字符的個數(shù)*/
    return i;
    【考點分析】
    本題考查:for循環(huán)語句遍歷字符串,并通過if條件語句,判斷字符串是否結(jié)束。
    【解題思路】
    從字符串中查找指定字符,需要使用循環(huán)判斷結(jié)構(gòu),循環(huán)語句用來遍歷字符串,循環(huán)條件為字符串沒有結(jié)束,即當前字符不是‘\0’,判斷語句用來判斷當前字符是否為指定字符。最后返回指定字符的個數(shù)。