主頁 > 後端開發 > 計算機等級考試二級C語言程式設計專項訓練題——程式修改題(一)

計算機等級考試二級C語言程式設計專項訓練題——程式修改題(一)

2022-11-16 06:58:54 後端開發

1、下列給定程式中函式proc的功能是:取出長整型變數s中偶數位上的數,依次構成一個新數放在t中,例如,當s中的數為123456789時,t中的數為2468,

請修改程式中的錯誤,使它能得出正確的結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
// ****found**** 
void proc(long s,long *t) 
{
    long sl=10;
    s/=10;
    *t=s%10;
// ****found**** 
    while (s>0)
    {
        s=s/100;
        *t=s%10*sl+*t;
        sl=sl*10; 
    } 
}
int main()
{
    long s,t;
    printf("Please enter s:");
    scanf("%ld",&s);
    proc(s,&t);
    printf("The result is:%ld\n",t);
    return 0;
}
1)錯誤:void proc(long s,long t)
正確:void proc(long s,long *t) 
(2)錯誤:while (s<0) 
正確:while (s>0) 
【決議】從主函式中實參可知,形參的第二個變數是長整型的指標變數,
因此“void proc(long s,long t)”應改為“void proc(long s,long *t)”;
要從低位開始取出長整型變數s中偶數位上的數,每次變數S要除以100,
然后判斷其是否大于0來決定是否要繼續,因此“while(s>0)”,
參考答案及決議

2、給定程式中,函式proc()的功能是:使陣列中的元素的值縮小5倍,

請修改程式中的錯誤,使它能得出正確的結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
// ****found**** 
void proc(double m[]) 
{ 
    int i;
    for (i=0; i<10;i++) 
    { 
// ****found**** 
       m[i]=m[i]/5;
    } 
} 
int main()
{
    int i;
    double m[10];
    printf("before calling\n");
    for (i=0;i<10;i++) 
    { 
        m[i]=i+20;
        printf("%lf ",m[i]);
    } 
    proc(m);
    printf("\nafter calling\n");
    for(i=0; i<10; i++) 
       printf("%lf ",m[i]);
    printf("\n");
    return 0;
}
1)錯誤:int  proc(int m[]) 
正確:void  proc(int m[]) 
(2)錯誤:m[i]=m[i]%5;
正確:m[i]=m[i]/5;
【決議】由主函式中的函式呼叫可知,函式proc()沒有回傳值,
因此“int  proc(int m[])”應改為“void  proc(int m[])”,題目中
要求使陣列中元素的值縮小到1/5,而不是對5取余,因此,
“m[i]=m[i]%5;”應改為“m[i]=m[i]/5;”,
參考答案及決議

3、下列給定程式中,函式proc()的功能是根據整型形參n,計算如下公式的值:

Y=1-1/(2*2)+1/(3*3)-1/(4*4)+…+(-1)(n+1)/(n*n)

例如,n的值為10,則應輸出0.817962,

請修改程式中的錯誤,使它能得到正確結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
double proc(int n) 
{ 
    double y=1.0;
// ****found**** 
    int i,j;
    for (i=2;i<=n;i++) 
    { 
       j=-j;
// ****found**** 
       y+=j/(i*i);
    } 
    return (y);
}
int main()
{
    printf("The result is %lf\n",proc(10));
    return 0;
}
1)錯誤:int i,j
     正確:int i,j=12)錯誤:y+=j/(i*i)
     正確:y+=1.0*j/(i*i)
【決議】變數j用于正負號切換,需要賦初值1,因此“int i,j”應改為
"int i,j=1”,C語言中整數除以整數結果為整數,即j/(i*i)的結果為0,
因此“y+=j/(i*i)”應改為“y+=1.0*j/(i*i)”
參考答案及決議

4、給定程式中,函式fun()的功能是判斷整數n是否是”完數”,當一個數的因子之和恰好等于這個數本身時,就稱這個數為“完數”,例如:6的因子包括1、2、3,而6=1+2+3,所以6是完數,如果是完數,函式回傳值為1,否則函式回傳值為0,陣列a中存放的是找到的因子,變數k中存放的是因子的個數,

請修改程式中的錯誤,使它能得到正確結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
int fun(int n,int a[],int *k)
{
    int m=0,i,t;
    t=n;
    for (i=1;i<n;i++)
       if (n%i==0)
       {  a[m++]=i;  t=t-i;}
 // ****found**** 
    *k=m;
// ****found**** 
if (t==0) 
return 1;
else 
return 0;
}
int main()
{
    int n,a[50],flag,i,k;
    scanf("%d",&n);
    flag=fun(n,a,&k);
    if (flag==1)
    {
        printf("%d 是完數,其因子為:",n);
        for (i=0;i<k;i++)
            printf("%d ",a[i]);
        printf("\n");
    }
    else
        printf("%d 不是完數,\n",n);
    return 0;
}
1)錯誤:k=m
     正確:*k=m
(2)錯誤:if (t=0) 
     正確:if (t==0) 
【決議】fun函式中通過指標間接訪問的方式向主函式中回傳整數n的因子個數,因此“k=m”應修改為“*k=m”,當t等于0時,回傳值1,因此“if (t=0)”應
該修改為“if (t==0)”,
參考答案及決議

5、下列給定程式中,函式proc()的功能是:從字串str中,洗掉所有大寫字母’F’,

請修改程式中的錯誤,使它能得到正確結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h> 
void proc(char *str) 
{ 
    int i,j;
    // ****found**** 
    for (i=j=0;str[i]!='0'; i++) 
       if (str[i]!='F') 
    // ****found**** 
          str[j]=str[i];
    str[j]='\0';
} 
int main()
{
    char  str[80];
    printf("\Enter a string:");
    gets(str);
    printf("The original string:");
    puts(str);
    proc(str);
    printf("The string after deleted:");
    puts(str);
    printf("\n");
    return 0;
}
1)錯誤:for (i=j=0;str[i]!='0'; i++)  
       正確:for (i=j=0;str[i]!='\0'; i++)
(2)錯誤:str[j]=str[i];
       正確:str[j++]=str[i];
【決議】根據題目中的要求,從字串str中洗掉所有大寫字母’F’,需要檢查字
符串str中的每一個字符,直到字串結束,因此,“str[i]!=’0’”應改為
“str[i]!=’\0’”;將每一個不是’F’的字符放入原來的字串中,形成新的字符
串,因此,“str[j]=str[i];”應改為“str[j++]=str[i];”,
參考答案及決議

6、下列給定的程式中,函式proc()的功能是:用選擇法對陣列中的m個元素按從小到大的順序進行排序,

例如,排序前的資料為:11  32 -52  14,則排序后的資料為:-52  11  14  32

請修改程式中的錯誤,使它能得到正確結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
#define M 20 
void proc(int a[],int n) 
{ 
    int i,j,k,t;
    for (j=0;j<n;j++)
    { 
        k=j;
// ****found**** 
        for (i=0; i<n;i++)
// ****found**** 
            if (a[i]>a[k])
                k=i;
        t=a[k];
        a[k]=a[j];
        a[j]=t;
    } 
} 
int main()
{
    int arr[M]={11,32,-52,14},i;
    printf("排序前的資料:");
    for (i=0;i<4;i++)
        printf("%d  ",arr[i]);
    printf("\n");
    proc(arr,4);
    printf("排序后的順序:");
    for (i=0;i<4;i++)
        printf("%d  ",arr[i]);
    printf("\n");
    return 0;
}
1)錯誤:for (i=0; i<n;i++)
正確:for (i=j; i<n;i++)
(2)錯誤:if (a[i]>a[k])
正確:if (a[i]<a[k])
【決議】按照選擇法排序的思想,每趟在未排好序的子序列中挑選最小數和序列
的第1個數交換,因此“for (i=0; i<n;i++)”應修改為“for (i=j+1; 
i<n;i++)”,題目要求從小到大排列,因此要選出較小的數,因此“if 
(a[i]>a[k])”應修改為“if (a[i]>a[k])”,
參考答案及決議

7、下列給定程式中函式fun()的功能是:用遞回演算法計算斐波拉契數列中第n項的值,從第1項起,斐波拉契數列為:1,1,2,3,5,8,13,21,…

例如,若給n輸入7,則該項的斐波拉契數值為13,

請改正程式中的錯誤,使它能得出正確結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構!

#include <stdio.h>
long fun(int g) 
{ 
// ****found**** 
    switch(g);
    { 
    case 0return 0;
// ****found**** 
    case 1case 2return 1;
    } 
    return (fun(g-1)+fun(g-2));
} 

int main()
{
    long fib;
    int n;
    scanf("%d",&n);
    printf("n=%d\n",n);
    fib=fun(n);
    printf("fib=%d\n",fib);
    return 0;
}
1)錯誤:switch(g);
正確:switch(g)
(2)錯誤:case 1;
正確:case 1:
【決議】按C語言的語法規則,switch(運算式)后不應該帶有“;”,case陳述句常
量后應該是“:”,
switch陳述句的一般形式如下:
switch(運算式){ 
case常量運算式1:陳述句1;
case常量運算式2:陳述句2;
case常量運算式n:陳述句i;
default:陳述句n+1;
} 
參考答案及決議

8、下列給定程式中,函式proc()的功能是:根據輸入的3個邊長(整型值),判斷能否構成三角形:若能構成等邊三角形,則回傳3;若是等腰三角形,則回傳2;若能構成三角形則回傳1;若不能,則回傳0,

例如,輸入3個邊長為3,4,5,實際輸入時,數與數之間以Enter鍵分隔而不是逗號,請修改程式中的錯誤,使它能得出正確的結果,

注意:不要改動main(  )函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
int proc(int a,int b,int c) 
{ 
// ****found**** 
    if (a+b>c || b+c>a || a+c>b) 
    { 
// ****found**** 
        if (a==b || b==c) 
           return 1;
        else if(a==b || b==c || a==c)
           return 2;
        else
            return 3;
    } 
    else
        return 0;
} 
int main()
{
    int a,b,c,shape;
    printf("Input a,b,c:");
    scanf("%d%d%d",&a,&b,&c);
    shape=proc(a,b,c);
    printf("The shape :%d\n",shape);
    return 0;
} 
1)錯誤:if (a+b>c || b+c>a || a+c>b)
正確:if (a+b>c && b+c>a && a+c>b)
(2)錯誤:if (a==b || b==c)
正確:if (a==b && b==c)
【決議】按構成三角形的條件:任意兩邊之和大于第三邊,因此“if (a+b>c ||
 b+c>a || a+c>b)”應改為:“if (a+b>c && b+c>a && a+c>b)”,同樣等
邊三角形是三條邊都相等, “if (a==b || b==c)”應改為“if (a==b && 
b==c)”,
參考答案及決議

9、下列給定程式中,函式proc()的功能是:讀入一個字串(長度<20),將該字串中的所有字符按ASCII碼升序排序后輸出,

例如,輸入opdye,則應輸出deopy,

請修改程式中的錯誤,使它能得到正確結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
#include <string.h>
// ****found**** 
int proc(char str[]) 
{ 
    char ch;
    unsigned int i,j;
    for (i=0; i<(strlen(str)-1);i++)
        for (j=i+1; j<strlen(str);j++)
//****found**** 
            if(str[i]<str[j]) 
            { 
               ch=str[j];
               str[j]=str[i];
               str[i]=ch;
            } 
} 
int main()
{
    char str[21];
    printf("Please enter a character string:");
    gets(str);
    printf("Before sorting:%s\n",str);
    proc(str);
    printf("After sorting decendingly:%s\n",str);
    return 0;
}
1)錯誤:int proc(char str[])
正確:void proc(char str[])
(2)錯誤:if(str[i]<str[j])
正確:if(str[i]>str[j])
【決議】由主函式中的函式呼叫可知,函式proc()沒有回傳值,因此,“int 
proc(char str[])”應改為“void proc(char str[])”,題目要求將字串中的所
有字符按ASCII碼升序排序,因此,“if(str[i]<str[j])”應改為
“if(str[i]>str[j])”,
參考答案及決議

10、給定程式中,函式fun的功能是:在有n名學生,2門課成績的結構體陣列std中,計算出第1門課程的平均分,作為函式值回傳,例如,主函式中給出了4名學生的資料,則程式運行的結果為:第1門課程的平均分是:76.125000 ,

請修改程式中的錯誤,使它能得到正確結果,

注意:不要改動main()函式,不得增行或刪行,也不得更改程式的結構,

#include <stdio.h>
typedef struct
{ 
    char num[10];
    double score[2];
}STU;  
double fun(STU std[],int n) 
{ 
    int i;
//****found**** 
    double sum;
    for (i=0; i<n; i++)
//****found**** 
       sum+=std[i].score[1];
    return sum/n;
} 
int main()
{
    STU std[]={{"GA005",76.5,82},{"GA003",66.5,73}, 
    {"GA002",80.5,66},{"GA004",81,56}};
    printf("第1門課程的平均分是 %lf\n",fun(std,4));
    return 0;
}
1)錯誤:double sum;
正確:double sum=0;
(2)錯誤:sum+=std[i].score[1];
正確:sum+=std[i].score[0];
【決議】變數sum用于成績累加求和,需要賦初值0,因此“double sum;”應改
為“double sum=0;”,求第1門功課的平均分,而陣列的下標從0開始,因此
“sum+=std[i].score[1];”應改為“sum+=std[i].score[0];”,
參考答案及決議

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/534134.html

標籤:其他

上一篇:在線客服系統原始碼開發實戰總結:Golang實作對接微信公眾號網頁授權介面功能

下一篇:為什么VScode不能正確編譯函式strtok?

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more