程序閱讀及填空(答案)_第1頁
程序閱讀及填空(答案)_第2頁
程序閱讀及填空(答案)_第3頁
程序閱讀及填空(答案)_第4頁
程序閱讀及填空(答案)_第5頁
已閱讀5頁,還剩8頁未讀 繼續免費閱讀

下載本文檔

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

文檔簡介

程序閱讀及填空(答案)程序閱讀及填空(答案)程序閱讀及填空(答案)xxx公司程序閱讀及填空(答案)文件編號:文件日期:修訂次數:第1.0次更改批準審核制定方案設計,管理制度一.程序閱讀題1.若運行時輸入100↙,寫出以下程序的運行結果。main(){inta;

scanf(“%d”,&a);

printf(“%s”,(a%2!=0)”No”:”Yes”);}答案:Yes2.寫出以下程序的運行結果。main(){inta=2,b=7,c=5;

switch(a>0){

case1:switch(b<0){

case1:printf(“@”);break;

case2:printf(“!”);break;

}

case0:switch(c==5){

case1:pritnf(“*”);break;

case2:printf(“#”);break;

default:printf(“#”);break;

}

default:printf(“&”);

}

printf(“\n”);}答案:*&3.寫出下面程序運行的結果。main(){inti,b,k=0;

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

b=i%2;

while(b--==0)k++;

}

printf(“%d,%d”,k,b);}答案:204.寫出下面程序運行的結果。main(){intk=1,n=263;

do{k*=n%10;n/=10;}while(n);

printf(“%d\n”,k);}答案:365.寫出下面程序運行的結果。main(){inta=10,y=0;

do{

a+=2;y+=a;

if(y>50)break;

}while(a=14);

printf(“a=%dy=%d\n”,a,y);}答案:a=16y=60數組部分:1.寫出下面程序的運行結果。答案:

main()答案:

{inta[6][6],i,j;

for(i=1;i<6;i++)

for(j=1;j<6;j++)

a[i][j]=(i/j)*(j/i);

for(i=1;i<6;i++){

for(j=1;j<6;j++)

printf(“%2d”,a[i][j]);

printf(“\n”);

}}2.寫出下面程序的運行結果。

main()

{inti=0;

chara[]=”abm”,b[]=”aqid”,c[10];

while(a[i]!=’\0’&&b[i]!=’\0’){

if(a[i]>=b[i])c[i]=a[i]-32;

elsec[i]=b[i]-32;

i++;

}

c[i]=’\0’;

puts(c);}答案:AQM3.當運行下面程序時,從鍵盤上輸入AabD↙,則寫出下面程序的運行結果。

main()

{chars[80];

inti=0;

gets(s);

while(s[i]!=’\0’){

if(s[i]<=’z’&&s[i]>=’a’)

s[i]=’z’+’a’-s[i];

i++;

}

puts(s);}答案:AzyD二.程序判斷題1.下面程序將輸入的大寫字母改寫成小寫字母輸出,其他字符不變;請判斷下面程序的正誤,如果錯誤請改正過來。main(){charc;

c=getchar();

c=(c>=’A’||c<=’Z’)c-32:c+32;

printf(“%c”,c);}答案:c=(c>=’A’||c<=’Z’)c-32:c+32;改為:c=(c>='A'&&c<='Z')c+32:c;

2.下面程序輸入兩個運算數x,y和一個運算符號op,然后輸出該運算結果的值,例如輸入3+5↙得到結果8;請判斷下面程序的正誤,如果錯誤請改正過來。

main()

{

floatx,y,r;

charop;

scanf(“%f%c%f”,&x,&op,&y);

switch(op){

case‘+’:r=x+y;

case‘-’:r=x-y;

case‘*’:r=x*y;

case‘/’:r=x/y;

}

printf(“%f”,r);}答案:每個Case分之后面加Break;三.程序填空題1、以下程序輸出x,y,z三個數中的最小值,請填(2)空使程序完整。main(){intx=4,y=5,z=8;

intu,v;

u=x<y【1】;

v=u<z【2】;

printf(“%d”,v);}答案:【1】x:y【2】u:z2、下述程序用“碾轉相除法”計算兩個整數m和n的最大公約數。該方法的基本思想是計算m和n相除的余數,如果余數為0則結束,此時的被除數就是最大公約數。否則,將除數作為新的被除數,余數作為新的除數,繼續計算m和n相除的余數,判斷是否為0,等等,請填(3)空使程序完整。main(){intm,n,w;

scanf(“%d,%d”,&m,&n);

while(n){

w=【1】;

m=【2】;

n=【3】;

}

printf(“%d”,m);}答案:【1】w=m%n;【2】m=n;【3】n=w;3、下面程序的功能是輸出1至100之間每位數的乘積大于每位數的和的數,請填(3)空使程序完整。main(){intn,k=1,s=0,m;

for(n=1;n<=100;n++){

k=1;s=0;

【1】;

while(【2】){

k*=m%10;

s+=m%10;

【3】;

}

if(k>s)printf(“%dd”,n);

}}答案:【1】m=n;【2】m!=0【3】m=m/10;4、下面程序按公式(課本169頁習題)求和并輸出結果,請填(3)空使程序完整。main(){

【1】;

intk;

for(k=1;k<=100;k++)

s+=k;

for(k=1;k<=50;k++)

s+=k*k;

for(k=1;k<=10;k++)

s+=【2】;

printf(“sum=【3】”,s);}答案:【1】floats=0;【2】1/k【3】%f數組部分:一、程序判斷:1.下面程序為數組輸入數據并輸出結果;判斷下面程序的正誤,如果錯誤請改正過來。

main()

{inta[3]={3*0};

inti;

for(i=0;i<4;i++)scanf(“%d”,&a[i]);

for(i=0;i<4;i++)printf(“%d”,a[i]);}答案:

for(i=0;i<3;i++)(只有3個數組元素,下標0~2)2.下面程序為數組輸入數據并輸出結果;判斷下面程序的正誤,如果錯誤請改正過來。

main()

{inta[3]={1,2,3},i;

scanf(“%d%d%d”,&a);

for(i=0;i<3;i++)printf(“%d”,a[i]);}答案:scanf("%d%d%d",&a[0],&a[1],&a[2]);3.下面程序的功能是:先將在字符串s中的字符按逆序存放到t串中,然后把s中的字符按正序連接到t串的后面。例如,當s中的字符串為:“ABCDE”時則t中的字符串應為:“EDCBAABCDE”;判斷下面程序的正誤,如果錯誤請改正過來。

main()

{chars[80],t[200];inti,sl;

gets(s);sl=strlen(s);

for(i=0;i<sl;i++)t[i]=s[sl-i];改為:t[i]=s[sl-i-1];

for(i=0;i<sl;i++)t[sl+i]=s[i];t[s1+i]='\0';加上語句:t[s1+i]='\0';

puts(t);}答案:見右邊修改語句4.下面程序的功能是:將n各無序整數從小到大排序;判斷下面程序的正誤,如果錯誤請改正過來。

main()

{inta[100],i,j,p,t,n=20;

for(j=0;j<n;j++)scanf(“%d”,&a[j]),改為:;

for(j=0;j<n-1;j++)

{p=j;

for(i=j+1;i<n-1;i++)n-1改為:n

if(a[p]>a[i])t=i;t改為:p

if(p!=j)

{t=a[j];a[j]=a[p];a[p]=t;}

}

for(j=0;j<n;j++)printf(“%d”,&a[j]);}答案:見右邊修改語句5.下面程序的功能是:統計子字符串substr在字符串str中出現的次數。例如,若字符串為aaaslkaaas,子字符串為as,則應輸出2;判斷下面程序的正誤,如果錯誤請改正過來。main(){charsubstr[80],str[80];main(){charsubstr[80],str[80];/*substr放需要統計的子字符串*/inti,j,k,num=0;gets(substr);gets(str);for(i=0;i<=strlen(str)-strlen(substr);i++)for(j=i,k=0;substr[k]==str[j];k++,j++)if(substr[k+1]=='\0') {num++;break;}printf("num=%d",num);}

{charsubstr[80],str[80];

inti,j,k,num=0;

gets(substr);gets(str);

for(i=0,str[i],i++)

for(j=i,k=0;substr[k]==str[j];k++,j++)

if(substr[k+1]!=’\0’){

num++;

break;

}

printf(“num=%d”,num);}答案:程序修改如右框所示。二、程序填空題1.下面程序可求出矩陣a的主對角線上的元素之和,請填(2)空使程序完整。

main()

{inta[3][3]={1,3,5,7,9,11,13,15,17},sum=0,i,j;

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

for(j=0;j<3;j++)

if(【1】)

sum=sum+【2】;

printf(“sum=%d”,sum);}答案:【1】i==j【2】a[i][j]2.下面程序將十進制整數base轉換成n進制,請填(3)空使程序完整。main(){inti=0main(){inti=0,base,n,j,num[20];scanf("%d",&n);scanf("%d",&base);do{i++;num[i]=base%n;base=base/n;}while(base!=0);for(j=i;j>=1;j--)printf("%d",num[j]);}{inti,base,n,j,num[20];

scanf(“%d”,&n);

scanf(“%d”,base);

do{

i++;

num[i]=【1】;

n=【2】;

}while(n!=0);

for(【3】);

printf(“%d”,num[j]);}答案:此程序有點小錯誤,紅色文字為改正錯誤,藍色文字為填空答案.3.下面程序的功能是輸入10個數,找出最大值和最小值所在的位置,并把兩者對調,然后輸出調整后的10個數,請填(3)空使程序完整。main(){inta[10],max,min,i,j,k;

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

scanf(“%d”,&a[i]);

max=min=a[0];

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

if(a[i]<min){min=a[i];【1】;}

if(a[i]>max){max=a[i];【2】;}

}/*循環完后,最小的數組元素下標放在變量j中,最大的放在變量k中*/

【3】;/*借助中間變量max,將最大最小兩數組元素交換*/

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

printf(“%d”,a[i]);}答案:【1】j=i【2】k=i【3】max=a[j];a[j]=a[k];a[k]=max;4.下面程序用“插入法”對數組a進行由小到大的排序,請填(3)空使程序完整。經典算法提示:簡單插入排序算法的基本思想使將數組處理n-1次,第k次處理是將第k個元素插入到目前的位置。第k次的元素是這樣插入的:在第k次處理時,前面的元素a[0],a[1],…,a[k-1]必定已排成了升序,將a[k]與a[k-1],a[k-2],…a[0]逐個比較(由后向前),若有a[j]<a[k],則a[k]插入到a[j]之后,否則a[k]維持原位不變。main(){inta[10]={191,3,6,4,11,7,25,13,89,10};

inti,j,k;

for(i=1;i<10;i++){

k=a[i];

j=【1】;

while(j>=0&&k>a[j]){/*k>a[j]改為:k<a[j]*/

【2】;

j--;

}

【3】=k;

}

for(i=0;i<10;i++)printf(“%d”,a[i]);}答案:【1】i-1【2】a[j+1]=a[j]【3】a[j+1]main(){inta[3]={3,5,10};intb[5]={1,6,26,37,48};main(){inta[3]={3,5,10};intb[5]={1,6,26,37,48};intc[10],i=0,j=0,k=0;while(i<3&&j<5)if(a[i]>b[j]){c[k]=b[j];k++;j++;} else{c[k]=a[i];k++;i++;}while(i<3){c[k]=a[i];i++;k++;}while(j<5){c[k]=b[j];j++;k++;}for(i=0;i<k;i++)printf("%d",c[i]);}此程序有點小錯誤,紅色文字為改正錯誤,藍色文字為填空答案.main(){inta[3]={5,9,10};

intb[5]={12,24,26,37,48};

intc[10],i=0,j=0,k=0;

while(i<3&&i<5)

if(【1】){

c[k]=b[j];k++;j++;

}else{

c[k]=a[j];k++;i++;

}

while(【2】){

{c[k]=a[j];i++;k++;}

while(【3】){

{c[k]=b[j];j++;k++;}

for(i=0;i<k;i++)printf(“%d”,c[i]);}6.下面程序的功能是將二維數組a中每個元素向右移一列,最右一列換到最左一列,移后的結果保存到b數組中,并按矩陣形式輸出a和b,請填(3)空使程序完整。main(){inta[2][3]main(){inta[2][3]={{4,5,6},{1,2,3}},b[2][3],i,j;for(i=0;i<2;i++){for(j=0;j<3;j++)printf("%5d",a[i][j]);printf("\n");}printf("\n");for(i=0;i<2;i++) for(j=0;j<3;j++) b[i][(j+1)%3]=a[i][j];for(i=0;i<2;i++){for(j=0;j<3;j++)printf("%5d",b[i][j]);printf("\n");}printf("\n");}main(){inta[2][3]={{4,5,6},{1,2,3}},b[2][3],i,j;

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

for(j=0;i<3;j++){

printf(“%5d”,a[i][j]);

【1】;

}

printf(“\n”);

}

for(【2】)b[i][0]=a[i][2];

for(i=0;i<2;i++){

for(j=0;i<3;j++){

printf(“%5d”,b[i][j]);

【3】;

}

printf(“\n”);

}}答案:此程序有錯誤,正確的程序見右框7.下面程序的功能是在一個字符串中查找一個指定的字符,若字符串中包含該字符則輸出該字符在字符串中第一次出現的位置(下標值),否則輸出-1,請填(2)空使程序完整。#include<>main(){charc=’a’;/*需要查找的字符*/

chart[50];

inti,j,k;

gets(t);

i=【1】;

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

if(【2】)

{j=k;break;}

elsej=-1;

printf(“%d”,j);}答案:【1】strlen(t)【2】t[k]==c8.下面程序用“順序查找法”查找數組a中是否存在某一關鍵字,請填(2)空使程序完整。main(){inta[10]={25,57,48,371,123,291,18,22,44};

inti=0,x;

scanf(“%d”,&x);

【1】;

while(a[i]!=x&&i<10)i++;

if(【

溫馨提示

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

評論

0/150

提交評論