當前位置:首頁 » 編程語言 » c語言數組練習題

c語言數組練習題

發布時間: 2022-12-25 20:11:52

㈠ 初學問幾道c語言數組的練習題

/*1,將一個一位數組a[10]中的元素值按逆序重新存放.假定數組中原來元素順序為:1,3,5,7,9,8,6,4,2,0,按逆序重新存放後元素的值位:0,2,4,6,8,9,7,5,3,1。要求:在程序中將數組初值初始化,輸出逆序重新存放後元素的值。*/
#include "stdafx.h"

int main(int argc,char* argv[])
{
int a[10]={1,3,5,7,9,8,6,4,2,0};//初始化。
int b[10];
printf("順序的數據:\n");
for(int j=0;j<10;j++)
{
printf("%d",a[j]);
printf(" ");
}
for(int i=0;i<10;i++)
{
b[10-1-i]=a[i];
}

printf("\n逆序後的數據:\n");
for(int n=0;n<10;n++)
{
printf("%d",b[n]);
printf(" ");
}

return 0;
}

/*2,有整型數組a[20],首先輸入一組非0整數(少於20個)到該數組中,以輸入0值為結束。編寫4個函數分別求該數組中元素的1,正數個數,2,正數平均值,3,負數個數,4,負數平均值,最後在主函數中輸入4個求出的值。提示:將數組定義為:int a[20],實際只用數組的前若干個元素。
*/

#include "stdafx.h"

int fun1(int *ar,int num)
{
int au=0;
for(int i=0;i<num;i++)
{
if(ar[i]>0)
{
au++;
}
}
printf("正數個數:%d\n",au);
return au;
}
int fun2(int *ar,int num)
{
int au=0;
for(int i=0;i<num;i++)
{
if(ar[i]>0)
{
au+=ar[i];
}
}
au=au/fun1(ar,num);
printf("正數平均值:%d\n",au);

return au;

}

int fun3(int *ar,int num)
{
int au=0;
for(int i=0;i<num;i++)
{
if(ar[i]<0)
{
au++;
}
}
printf("負數個數:%d\n",au);
return au;
}
int fun4(int *ar,int num)
{
int au=0;
for(int i=0;i<num;i++)
{
if(ar[i]<0)
{
au+=ar[i];
}
}
au=au/fun1(ar,num);
printf("負數平均值:%d\n",au);

return au;

}

int main(int argc,char* argv[])
{
int a[20];
int num,date;
printf("請輸入數據:\n");
for(num=0;num<20;num++)
{
scanf("%d",&date);
if(date==0)
{
break;
}
a[num]=date;
}
fun2(a,num);
fun4(a,num);
return 0;
}

/*3,任意輸入一個4位數,存入變數i,將該數的每一位上的數字,分解到整型數組a[]中,用選擇法將a[]數組中的數排成升序,並輸入a[]數組的內容。要求選擇法排序在函數中完成。
如:int i,a[4];輸入i=8362
分解後:a[0]=2,a[1]=6,a[2]=3,a[3]=8
排序後:a[0]=2,a[1]=3,a[2]=6,a[3]=8
運行時,輸入8362
輸出2368 */
#include "stdafx.h"

void fun(int *a,int num)
{
for(int i=0;i<num-1;i++)
for(int j=i+1;j<num;j++)
{
if(a[i]>a[j])
{
int date=a[i];
a[i]=a[j];
a[j]=date;
}
}
}

int main(int argc,char* argv[])
{
int i=0;
int a[4];
printf("請輸入四位整數:\n");
scanf("%d",&i);
for(int s=1000,l=0;l<4;s/=10,l++)
{
a[l]=i/s;
i%=s;
}
fun(a,4);
for(int n=0;n<4;n++)
{
printf("%d",a[n]);
}

return 0;
}

,4,給定2維數組如下,求該數組2條對角線元素之和
a=3 6 4 6
8 3 1 3
4 7 1 2
2 9 5 3
要求:1,在主函數中實現:數組賦初值及求和結果的輸出 */
#include "stdafx.h"

int main(int argc,char* argv[])
{
int a[4][4]={{3,6,4,6},{8,3,1,3},{4,7,1,2},{2,9,5,3}};
int num=0;

for(int i=0,j=0;i<4;i++,j++)
{
num+=a[i][j];
}

printf("第一對角線之和:",num);
printf("%d\n",num);

for(i=4-1,j=4-1;i>0;i--,j--)
{
num+=a[i][j];
}

printf("第二對角線之和:",num);
printf("%d\n",num);
return 0;
}

/*6,編寫一個函數viod my_strcpy(char s1[],char s2[]),將s2中的字元串拷貝到數組s1中去。要求:
1,不允許使用C語言的庫函數strcpy()
2,在主函數中輸入2個字元串,調用函數my_strcpy()進行字元串拷貝,並在主函數中輸入字元串s1,s2內容。
注意:應該將字元數組s1[]定義足夠長,使之能存放連接後的字元串 */
#include "stdafx.h"

void str(char *str1,char *str2)
{
while(*str2)
{
*str1++=*str2++;
}
}

int main(int argc,char* argv[])
{
char st1[]="test str";
char st2[20]="";

str(st2,st1);
printf("%s\n",st2);
return 0;
}

/*7,輸入2個字元串,將對應字母交叉組成第三個字元串,最後輸入第三個字元串。例如輸入的2個字元串分別是「abcd」和「1234」,則合並後的字元串是「a1b2c3d4」。若2個字元串的長度不等,則其中的一個字元串多餘的部分放在結果字元串的尾部,如2個字元串分別是「banana」和「12」,則合並後的字元串是「b1a2nana」
要求:第一個字元串的第一個字母總是結果串的第一個字母。
*/
#include "stdafx.h"

void combinstr(char *str1,char *str2,char *str3)
{
for(;*str1||*str2;)
{
if(*str1)
{
*str3++=*str1++;
}
if(*str2)
{
*str3++=*str2++;
}
}
}

int main(int argc,char* argv[])
{
char st1[]="abcdefghi";
char st2[]="1234";
char st3[64]="";

combinstr(st1,st2,st3);
printf("%s\n",st3);
return 0;
}
只有第五個沒有了,你想怎麼示範?
算了隨便弄個可以看效果的了:/*5,已知5個學生的3門成績
COURSE1 COURSE2 COURSE3 AVER
STUD1 76 80 90
STUD2 90 65 77
STUD3 63 55 70
STUD4 90 92 97
STUD5 73 69 82
要求:1,求出並輸入每個學生的平均成績
2,求出並輸入每門課的平均成績

*/
#include "stdafx.h"

int main(int argc,char* argv[])
{
float stud[5][3]={{76,80,90},{90,65,77},{63,55,70},{90,92,97},{73,69,82}};
float num=0;
for(int i=0;i<5;i++)
{
for(int j=0;j<3;j++)
{
num+=stud[i][j];
}
num/=3;
printf("\n第%d個學生的平均成績:\n",i+1);
printf("%f\n",num);
num=0;

}

for(i=0;i<3;i++)
{
for(int j=0;j<5;j++)
{
num+=stud[i][j];
}
num/=5;
printf("\n第%d科的平均成績:\n",i+1);
printf("%f\n",num);
num=0;
}

return 0;
}

㈡ 推薦一些有關C語言數組的練習題。

06年南開上機題

1: 第1題 m個人的成績存放在score數組中,請編寫函數fun,它的功能是:將低於平均分的人作為函數值返回,將低於平均分的分數放在below所指定的函數中。
答案:int fun(int score[],int m,int below[])
{
int i,k=0,aver=0;
for(i=0;i<m;i++)
aver+=score[i];
aver/=m;
for(i=0;i<m;i++)
if(score[i]<aver)
{
below[k]=score[i];
k++;
}
return k;
}
2: 第2題 請編寫函數fun,它的功能是:求出1到100之內能北7或者11整除,但不能同時北7和11整除的所有證書,並將他們放在a所指的數組中,通過n返回這些數的個數。
答案:void fun(int *a, int *n)
{
int i,j=0;
for(i=2;i<1000;i++)
if ((i%7==0 || i%11==0) && i%77!=0)
a[j++]=i;
*n=j;
}

3: 第3題 請編寫函數void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶數的各整數,並按從小到大的順序放在pp所指的數組中,這些除數的個數通過形參n返回。
答案:void fun(int x, int pp[ ], int *n)
{
int i=1,j=0;k=0,*t=pp;
for(i=0;i<=x;i++)
if(i%2!=0)
{
t[j]=I;
j++;
}
for(i=0;i<j;i++)
if(x%t[i]==0)
{
pp[k]=t[i];
k++;
}
*n=k;
}

4: 第4題 請編寫一個函數void fun(char *tt,int pp[]),統計在tt字元中"a"到"z"26各字母各自出現的次數,並依次放在pp所指的數組中。
答案:void fun(char *tt, int pp[])
{
int i;
for (i=0;i<26;i++)
pp[i]=0;
while (*tt)
{
switch (*tt)
{
case 『a』: pp[0]++;break;
case 『b』: pp[1]++;break;
case 『c』: pp[2]++;break;
case 『d』: pp[3]++;break;
case 『e』: pp[4]++;break;
case 『f』: pp[5]++;break;
case 『g』: pp[6]++;break;
case 『h』: pp[7]++;break;
case 『i』: pp[8]++;break;
case 『j』: pp[9]++;break;
case 『k』: pp[10]++;break;
case 『l』: pp[11]++;break;
case 『m』: pp[12]++;break;
case 『n』: pp[12]++;break;
case 『o』: pp[14]++;break;
case 『p』: pp[15]++;break;
case 『q』: pp[16]++;break;
case 『r』: pp[17]++;break;
case 『s』: pp[18]++;break;
case 『t』: pp[19]++;break;
case 『u』: pp[20]++;break;
case 『v』: pp[21]++;break;
case 『w』: pp[22]++;break;
case 『x』: pp[23]++;break;
case 『y』: pp[24]++;break;
case 『z』: pp[25]++;break;
}
tt++;
}
}
5: 第5題 請編寫一個函數void fun(int m,int k,int xx[]),該函數的功能是:將大於整數m且緊靠m的k各素數存入xx所指的數組中。
答案:void fun(int m, int k, int xx[])
{
int g=0,I,j,flag=1;
for(i=m+1;i<m*m;i++)
{
for(j=0;j<I;j++)
{
if(i%j!=0)
flag=1;
else
{
flag=0;
break;
}
}
if (flag==1 && j>=i)
{
if (k>=0)
{
xx[g++]=i;
k--;
}
else
break;
}
}
}

6: 第6題 請編寫一個函數void fun(char a[],char[],int n),其功能是:刪除以各字元串中指定下標的字元。其中,a指向原字元串,刪除後的字元串存放在b所指的數組中,n中存放指定的下標。
答案:void fun(char a[],char b[], int n)
{
int I,j=0;
for (i=0;i<LEN;i++)
if (i!=n)
{
b[j]=a[i];
j++;
}
b[j]=『\0』;
}

7: 第7題 請編寫一個函數int fun(int *s,int t,int *k),用來求除數組的最大元素在數組中的下標並存放在k所指的儲存單元中。
答案:void fun (int *s, int t, int *k)
{
int I, max;
max=s[0];
for(i=0;i<t;i++)
if (s[i]>max)
{
max=s[i];
*k=I;
}
}

8: 第8題 編寫函數fun,功能是:根據以下攻勢計算s,計算結果作為函數值返回;n通過形參傳入。S=1+1/(1+2)+1/(1+2+3)+…….+1/(1+2+3+4+……+n)
答案:float fun (int n)
{
int i;
float s=1.0, t=1.0;
for(i=2;i<=n;i++)
{
t=t+i;
s=s+1/t;
}
return s;
}

9: 第9題 編寫一個函數fun,它的功能是:根據以下公式求p的值,結果由函數值帶回。M與n為兩個正整數,且要求m>n。 p=m!/n!(m-n)!
答案:float fun(int m, int n)
{
float p,t=1.0;
int I;
for (i=1;i<=m;i++)
t=t*I;
p=t;
for(t=1.0,i=1;i<=n;i++)
t=t*I;
p=p/t;
for(t=1.0,i=1;i<=m-n;i++)
t=t*I;
p=p/t;
return p;
}

10: 第10題 編寫函數fun,它的功能是:利用以下的簡單迭代方法求方程cos(x)-x=0的一個實根。
迭代步驟如下:(1)取x1初值為0.0; (2)x0=x1,把x1的值賦各x0;
(3)x1=cos(x0),求出一個新的x1;
(4)若x0-x1的絕對值小於0.000001,則執行步驟(5),否則執行步驟(2);
(5)所求x1就是方程cos(x)-x=0的一個實根,作為函數值返回。
程序將輸出root=0.739085。
答案:float fun()
{
float x1=0.0,x0;
do
{
x0=x1;
x1=cos(x0);
}
while(fabs(x0-x1)>1e-6);
return x1;
}

11: 第11題 下列程序定義了n×n的二維數組,並在主函數中自動賦值。請編寫函數 fun(int a[][n]),該函數的功能是:使數組左下半三角元素中的值全部置成0。
答案:int fun(int a[][N])
{
int I,j;
for(i=0;i<N;i++)
for(j=0;j<=I;j++)
a[i][j]=0;
}

12: 第12題 下列程序定義了n×n的二維數組,並在主函數中賦值。請編寫函數fun,函數的功能使求出數組周邊元素的平均值並作為函數值返回給主函數中的s。
答案:double fun(int w[][N])
{
int I,j,k=0;
double s=0.0;
for(j=0;j<N;j++)
{
s+=w[0][j];
k++;
}
for(j=0;j<N;j++)
{
s+=w[N-1][j];
k++;
}
for(i=1;i<=N-2;i++)
{
s+=w[i][0];
k++;
}
for(i=1;i<=N-2;i++)
{
s+=w[i][N-1];
k++;
}
return s/=k;
}

13: 第13題 請編寫一個函數void fun(int tt[m][n],int pp[n]),tt指向一個m行n列的二維函數組,求出二維函數組每列中最小元素,並依次放入pp所指定一維數組中。二維數組中的數已在主函數中賦予。
答案:void fun(int tt[M][N], int pp[N])
{
int I,j,min;
for(j=0;j<N;j++)
{
min=tt[0][j];
for(i=0;i<M;i++)
{
if (tt[i][j]<min)
min=tt[i][j];
}
pp[j]=min;
}
}

14: 第14題 請別寫函數fun,函數的功能使求出二維數組周邊元素之和,作為函數值返回。二維數組中的值在主函數中賦予。
答案:int fun(int a[M][N])
{
int I,j,s=0;
for(j=0;j<N;j++)
{
s+=a[0][j];
s+=a[M-1][j];
}
for(i=1;i<=M-2;i++)
{
s+=a[i][0];
s+=a[i][N-1];
}
return s;
}

15: 第15題 請編寫一個函數unsigned fun(unsigned w),w使一個大於10的無符號整數,若w使n(n≥2)位的整數,則函數求出w後n-1位的數作為函數值返回。
答案:unsigned fun(unsigned w)
{
unsigned t,s=0,s1=1,p=0;
t=w;
while(t>10)
{
if(t/10)
p=t%10;
s=s+p*s1;
s1=s1*10;
t=t/10;
}
return s;
}

16: 第16題 請編寫一個函數float fun(double h),函數的功能使對變數h中的值保留2位小樹,並對第三位進行四捨五入(規定h中的值位正數)。
答案:float fun(float h)
{
long t;
float s;
h=h*1000;
t=(h+5)/10;
s=(float)t/100.0;
return s;
}

17: 第17題 請編寫一個函數fun(char *s),該函數的功能使把字元串中的內容擬置。
答案:void fun(char *s)
{
char ch;
int I,m,n;
i=0;
m=n=strlen(s)-1;
while(i<(n+1)/2)
{
ch=s[i];
s[i]=s[m];
s[m]=ch;
i++;
m--;
}
}

18: 第18題 編寫程序,實現矩陣(3行3列)的轉置(即行列互換)。
答案:void fun(int array[3][3])
{
int I,j,temp;
for(i=0;i<3;i++)
for(j=0;j<I,j++)
{
temp=array[i][j];
array[i][j]=array[j][i];
array[j][i]=temp;
}
}

19: 第19題 編寫函數fun,該函數的功能是:從字元中刪除指定的字元,同一字母的大、小寫按不同字元處理。
答案:void fun(char s[],int c)
{
int i=0;
char *p;
p=s;
while(*p)
{
if(*p!=c)
{
s[i]=*p;
i++;
}
p++;
}
s[i]=『\0』;
}

20: 第20題 編寫函數int fun(int lim,int aa[max]),該函數的功能是求出小於或等於lim的所有素數並放在aa數組中,該函數返回所求的素數的個數。
答案:int fun(int lim, int aa[MAX])
{
int k=0,I,j;
for(i=lim;i>1;i--)
{
for(j=2;j<i;j++)
if(i%j==0)
break;
else
continue;
if(j>=i)
{
aa[k]=i;
k++;
}
}
return k++;
}

21: 第21題 請編寫函數fun,對長度位7個字元的字元串,除首尾字元外,將其餘5個字元按ascii碼降序排列。
答案:void fun(char *s,int num)
{
char t;
int I,j;
for(i=1;i<num-2;i++)
for(j=i+1;j<num-1;j++)
if(s[i]<s[j])
{
t=s[i];
s[i]=s[j];
s[j]=t;
}
}

22: 第22題 n名學生的成績已在主函數中放入一個帶頭節點的鏈表結構中,h指向鏈表的頭節點。請編寫函數fun,它的功能是:找出學生的最高分,由函數值返回。
答案:double fun(STREC *h)
{
double max;
STREC *q=h;
max=h->s;
do
{
if(q->s>max)
max=q->s;
q=q->next;
}
while(q!=0);
return max;
}

23: 第23題 請編寫函數fun,該函數的功能是:判斷字元串是否為迴文?若是則函數返回1,主函數中輸出yes,否則返回0,主函數中輸出no。迴文是指順讀和倒讀都是一樣的字元串。
答案:int fun(char *str)
{
int I,n=0;fg=1;
char *p=str;
while (*p)
{
n++;
p++;
}
for(i=0;i<n/2;i++)
if (str[i]==str[n-1-i]);
else
{
fg=0;
break;
}
return fg;
}

24: 第24題 請編寫一個函數fun,它的功能是:將一個字元串轉換為一個整數(不得調用c語言提供的將字元串轉換為整數的函數)。
答案:long fun (char *p)
{
long s=0,t;
int i=0,j,n=strlen(p),k,s1;
if(p[0]==『-』)
i++;
for(j=I;j<=n-1;j++)
{
t=p[j]-『0』;
s1=10;
for(k=j;k<n-1;k++)
t*=s1;
s+=t;
}
if(p[0]==『-』)
return –s;
else
return s;
}

25: 第25題 請編寫一個函數fun,它的功能是:比較兩個字元串的長度,(不得調用c語言提供的求字元串長度的函數),函數返回較長的字元串。若兩個字元串長度相同,則返回第一個字元串。
答案:char *fun(char *s,char *t)
{
char *p,*t1=t,*s1=s;
int n=0;m=0;
while (*s1)
{
n++;
s1++;
}
while(*t1)
{
m++;
t1++;
}
if(n>=m)
p=s;
else
p=t;
return p;
}

26: 第26題 請編寫一個函數fun,它的功能是:根據以下公式求x的值(要求滿足精度0.0005,即某項小於0.0005時停止迭代):
x/2=1+1/3+1×2/3×5+1×2×3/3×5×7+1×2×3×4/3×5×7×9+…+1×2×3×…×n/3×5×7×(2n+1)
程序運行後,如果輸入精度0.0005,則程序輸出為3.14…。
答案:double fun(double eps)
{
double s;
float n,t,pi;
t=1;pi=0;n=1.0;s=1.0;
while((fabs(s))>=eps)
{
pi+=s;
t=n/(2*n+1);
s*=t;
n++;
}
pi=pi*2;
return pi;
}

27: 第27題 請編寫一個函數fun,它的功能是:求除1到m之內(含m)能北7或11整除的所有整數放在數組a中,通過n返回這些數的個數。
答案:void fun(int m, int *a, int *n)
{
int I,j=0; *n=0;
for(i=1;i<=m;i++)
if (i%7==0 || i%11 ==0)
{
a[j]=I;
j++;
}
*n=j;
}

28: 第28題 請編寫一個函數fun,它的功能是:找出一維整型數組元素中最大的值和它所在的下標,最大的值和它所在的下標通過形參傳回。數組元素中的值已在主函數中賦予。主函數中x是數組名,n 是x中的數據個數,max存放最大值,index存放最大值所在元素的下標。
答案:void fun (int a[],int n, int *max, int *d)
{
int I;
*max=a[0];
*d=0;
for(i=0;I<n;i++)
if(a[i]>*max)
{
*max=a[i];
*d=I;
}
}

29: 第29題 請編寫一個函數fun,它的功能是:將ss所指字元串中所有下標為奇數位置上的字母轉換為大寫(若該位置上不是字母,則不轉換)。
答案:void fun(char *ss)
{
int I,n;
n=strlen(ss);
for(i=1;i<n;i+=2)
if(ss[i]>=『a』&& ss[i]<=『z』)
ss[i]=ss[i]-32;
}

30: 第30題 請編寫一個函數fun,它的功能是:求除一個2×m整型二維數組中最大元素的值,並將此值返回調用函數。
答案:int fun(int a[][M])
{
int I,j,max;
max=a[0][0];
for(i=0;i<2;i++)
for(j=0;j<M;j++)
if(a[i][j]>max)
max=a[i][j];
return max;
}

31: 第31題 請編寫函數fun,其功能是:將s所指字元串中除了下標為偶數、同時ascii值也為偶數的字元外,其餘的全都刪除;串中剩餘字元所形成的一個新串放在t所指的一個數組中。
答案:void fun(char *s,char t[])
{
int I,j=0,n;
n=strlen(s);
for(i=0;I,n;i++)
if(i%2==0&&s[i]%2==0)
{
t[j]=s[i];
j++;
}
t[j]=『\0』;
}

32: 第32題 請編寫函數fun,其功能是:將s所指字元串中除了下標為奇數、同時ascii值也為奇數的字元之外,其餘的所有字元都刪除,串中剩餘字元所形成的一個新串放在t所指的一個數組中。
答案:void fun(char *s,char t[])
{
int I,j=0,n;
n=strlen(s);
for(i=0;I,n;i++)
if(i%2!=0&&s[i]%2!=0)
{
t[j]=s[i];
j++;
}
t[j]=『\0』;
}

33: 第33題 假定輸入的字元串中只包含字母和*號。請編寫函數fun,它的功能是:使字元串中尾部的*號不得多於n個;若多於n個,則刪除多於的*號;若少於或等於n個,則什麼也不做,字元串中間和前面的*號不刪除。
答案:void fun(char *a,int n)
{
int i=0;k=0;
char *p, *t;
p=t=a;
while (*t)
t++;
t--;
while(*t==『*』)
{
k++;
t--;
}
t++;
if(k>n)
{
while (*p&&p<t+n)
{
a[i]=*p;
i++;
p++;
}
a[i]=『\0』;
}
}

34: 第34題 學生的記錄由學號和成績組成,n名學生的數據已在主函數中放入結構體數組s中,請編寫函數fun,它的功能使:把分數最高的學生數據放在h所指的數組中,注意:分數最高的學生可能不止一個,函數返回分數最高的學生的人數。
答案:int fun (STREC *a, STREC *b)
{
int I,j=0,n=0, max;
max=a[0].s;
for(i=0;i<N;i++)
if(a[i].s>max)
max=a[i].s;
for(i=0;i<N;i++)
if(a[i].s==max)
{
*(b+j)=a[i];
j++;
n++;
}
return n;
}

35: 第35題 請編寫一個函數,用來刪除字元串中的所有空格。
答案:void fun(char *str)
{
int i=0;
char *p=str;
while (*p)
{
if(*p!=『』)
{
str[i]=*p;
i++;
}
p++;
}
str[i]=『\0』;
}

36: 第36題 假定輸入的字元串中只包含字母和*號。請編寫函數fun,它的功能是:將字元串中的前導*號全部移到字元串的尾部。
答案:void fun(char *a)
{
int i=0,n=0;
char *p;
p=a;
while (*p==『*』)
{
n++;
p++;
}
while (*p)
{
a[i]=*p;
i++;
p++;
}
while(n!=0)
{
a[i]=『*』;
i++;
n--;
}
a[i]=『\0』;
}

37: 第37題 某學生的記錄由學號、8門課程成績和平均分組成,學號和8門課程的成績已在主函數中給出。請編寫函數fun,它的功能是:求出該學生的平均分放在記錄的ave成員中。請自己定義正確的形參。
答案:void fun(STREC *p)
{
double av=0.0;
int i:
for(i=0;i<N;i++)
av+=p->s[i];
av/=N;
p->ave=av;
}

㈢ C語言數組練習題

A D D B C
C C D B D

㈣ c語言數組題

1、B 這兩種定義不同,因為x字元串後面有\0,多1個位元組。
2、D 字元串只能這么比較
3、A 該程序就是將字元串轉變為整型
4、B 選項D不行,必須在語句前申明變數
5、B
6、C 只能省略第一個值
7、C
8、B 只能省略第一個值
9、C 注意數組邊界,a[4]是0~3,沒有4。
10、D
11、D 舉幾個特例
12、B scanf輸入字元串是不用加&的(和變數不同),gets()只能有一個參數,即gets(a);
13、a[i]i % 4 == 0printf("\n");

㈤ C語言 數組選擇題

A
D (c2 - 0)是字元'2'的ASCII值,所以不是數字2.
a[1]數組a的第二個數
'd' - c1 -> 'd' - 'b' 等於2
a['3' - c2] -> a[ '3' - '2'] -> a[1]

㈥ C語言數組題

1、給整型二維數組 b[3][4]輸入12個數據,計算並輸出數組中所有正數之和、所有負數之和。
2、青年歌手參加歌曲大獎賽,有10個評委進行打分,試編程求這位選手的平均得分(去掉一個最高分和一個最低分)。
分析:這道題的核心是排序。將評委所打的10個分數利用數組按增序(或降序)排列,計算數組中除第一個和最後一個分數以外的數的平均分。
3、設二維數組 b[5][4]中有鞍點,即b[i][j]元素值在第i行中最小,且在第j列中最大,試編寫一程序找出所有的鞍點,並輸出其下標值。也可能沒有。
4、從鍵盤輸入一數,然後在一個整型一維數組a[20]中,用折半查找法找出該數是數組中第幾個元素的值。如果該數不在數組中,則列印」No found」。
5、編程列印如下圖形:
*
* *
* *
* *
*
6、有一電文,已按下列規律譯成解碼:
A→Z a→z
B→Y b→y
C→X c→x
… …
即第一個字母變成第26個字母,第i個字母變成第(26-i+1)個字母。非字母字元不變。編寫一個程序將密碼譯成原文,並輸出密碼和原文。

㈦ C語言數組的作業題,幫幫忙啊,急急!!!!!!

唉,很簡單的題目,自己都不願意做!!

一、
1、C 2、A 3、D 4、B 5、B 6、D 7、C 8、B 9、D 10、A

二、
s=-16

三、編程題
1、
#include<stdio.h>
main()
{
int a[9],i,j,t;

for(i=0;i<9;i++)
{
scanf("%d",&a[i]);
}
//排序前
for(i=0;i<9;i++)
{
printf("%d ",a[i]);
}
printf("\n");

//排序
for(i=0;i<9;i++)
for(j=9-1;j>i;j--)
if(a[j]<a[j-1])
{
t=a[j];
a[j-1]=a[j];
a[j]=t;
}

//排序後
for(i=0;i<9;i++)
{
printf("%d ",a[i]);
}
printf("\n");
}

2、
#include<stdio.h>
main()
{
char a[80],*p;

gets(a);
for(p=a;*p!=0;p++)
{
if(*p>='A'&&*p<='Z')
*p+='a'-'A';
}
puts(a);
}

㈧ 求解幾道關於C語言數組的題目

第一題:
#include<stdio.h>
#include<stdlib.h>
int
main()
{
int
a[5]={1,2,3,4,5};
int
b[5]={11,4,2,7,9};
int
c[5];
printf("數組c的元素為:");
for(int
i=0;i<5;i++)
{
c[i]=a[i]+b[i];
printf("%3d",c[i]);
}
return
0;
}
第二題:
#include<stdio.h>
#include<stdlib.h>
void
change(int
array[],int
n)
{
for(int
i=0;i<(n/2);i++)
{
int
temp;
temp=array[i];
array[i]=array[n-1-i];
array[n-1-i]=temp;
}
}
//Test
main
function
int
main()
{
int
a[]={1,2,3,4,5,6};
change(a,6);
for(int
i=0;i<6;i++)
{
printf("%d",a[i]);
}
return
0;
}
第三題:
#include<stdio.h>
#include<stdlib.h>
int
main()
{
int
a[2][3]={{1,2,3},{4,5,6}};
int
b[3][2]={{4,2},{3,0},{1,7}};
int
c[2][2]={0};//初始化值為0
printf("C的矩陣結構為:\n");
for(int
i=0;i<2;i++)
{
for(int
j=0;j<2;j++)
{
for(int
k=0;k<3;k++)
{
c[i][j]+=a[i][k]*b[k][j];
}
printf("%3d",c[i][j]);
if(i==0&&j==1)
printf("\n");
}
}
return
0;
}
第四題:
#include<stdio.h>
#include<stdlib.h>
int
Days(int
y,int
m,int
d)
{
int
days_of_month[2][12]={{31,29,31,30,31,30,31,31,30,31,30,31},
{31,28,31,30,31,30,31,31,30,31,30,31}};
int
day=0;
int
count=0;
//判斷是否為閏年
if((y%4==0&&y%100!=0)||(y%400==0))
{
printf("%d是閏年",y);
for(int
i=0;i<m-1;i++)
{
count+=days_of_month[0][i];
}
day=count+d;
}
else
{
printf("%d不是閏年",y);
for(int
i=0;i<m-1;i++)
{
count+=days_of_month[1][i];
}
day=count+d;
}
return
day;
}
int
main()
{
int
y,m,d;
printf("請輸入你要查詢的年月日:");
scanf("%d%d%d",&y,&m,&d);
int
day=Days(y,m,d);
printf("是%d年的第%d天",y,day);
return
0;
}

㈨ C語言數組題

1題:
#include <stdio.h>
main()
{

int a[10]={89,90,84,78,84,67,88,92,79,73};
int i,j=0;
float aver,sum=0;
for(i=0;i<10;i++)
{
sum+=a[i];
}
aver=sum/10;
printf("%4.2f",aver);

for(i=0;i<10;i++)
{
if(a[i]<aver)
j++;
}
printf("di yu pingjun ren shu:%d",j);
getch();
}

2題:
#include <stdio.h>
#include <math.h>

struct stu
{
float yuwen;
float shuxue;
float yingyu;
}stu[10];
main()
{
int i;
float sum1=0,sum2=0,sum3=0;
float ave1,ave2,ave3;
printf("qing shuru chengji:");
for(i=0;i<10;i++)
{
scanf("%f%f%f",&stu[i].yuwen,&stu[i].shuxue,&stu[i].yingyu);
printf("\n");
}

for(i=0;i<10;i++)
{
sum1+=stu[i].yuwen;
sum2+=stu[i].shuxue;
sum3+=stu[i].yingyu;
}
ave1=sum1/10;
ave2=sum2/10;
ave3=sum3/10;
printf("yuwen pingjun ; %f\n",ave1);
printf("shuxue pingjun ; %f\n",ave2);
printf("yingyu pingjun ; %f\n",ave3);
getch();
}

3題:

#include <stdio.h>
main()
{
int a[8][8],i,j;
for(i=0;i<8;i++)
{
a[i][i]=1;
a[i][0]=1;
}
for(i=2;i<8;i++)
for(j=1;j<8;j++)
{
a[i][j]=a[i-1][j-1]+a[i-1][j];
}
for(i=0;i<8;i++)
{
for(j=0;j<=i;j++)
printf("%5d",a[i][j]);
printf("\n");
}
getch();
}

㈩ C語言數組程序題。。。

intmain(){
intnum1[20],num2[20],num3[20],num4[20];
inti,j,j1=0,j2=0,k1=0,k2=0,tmp,flag=0;
chara=0;
while(a!=' '){
scanf("%d",&num1[j1++]);
a=getchar();
}
a=0;
while(a!=' '){
scanf("%d",&num2[j2++]);
a=getchar();
}


for(i=0;i<j1;i++){
for(j=0;j<j2;j++){
if(num1[i]==num2[j]){
flag=1;
}
}
if(flag){
num3[k1++]=num1[i];

}else{
num4[k2++]=num1[i];

}
flag=0;
}
for(i=0;i<j2;i++){
for(j=0;j<j1;j++){
if(num2[i]==num1[j]){
flag=1;
}
}
if(!flag){
num4[k2++]=num2[i];

}
flag=0;
}
for(i=0;i<(k2-1);i++){
for(j=i+1;j<k2;j++){
if(num4[i]>num4[j]){
tmp=num4[i];
num4[i]=num4[j];
num4[j]=tmp;
}
}
}
for(i=0;i<k2;i++){

printf("%d",num4[i]);
}
printf(" ");

for(i=0;i<(k1-1);i++){
for(j=i+1;j<k1;j++){
if(num3[i]>num3[j]){
tmp=num3[i];
num3[i]=num3[j];
num3[j]=tmp;
}
}
}
for(i=0;i<k1;i++){

printf("%d",num3[i]);
}
return0;
}

熱點內容
gdb調試文件夾 發布:2024-05-07 04:03:25 瀏覽:153
玩5款大型游戲需要什麼配置 發布:2024-05-07 03:59:09 瀏覽:89
什麼安卓游戲畫面炫酷 發布:2024-05-07 03:58:18 瀏覽:73
無錫五洋賽德壓縮機有限公司 發布:2024-05-07 03:28:05 瀏覽:152
安卓手機如何打開qrs 發布:2024-05-07 03:18:31 瀏覽:466
c語言給數組排序 發布:2024-05-07 03:18:30 瀏覽:76
職工個人所得稅登錄密碼是多少 發布:2024-05-07 03:14:22 瀏覽:707
編譯程序組成部分 發布:2024-05-07 03:02:07 瀏覽:97
伺服器怎麼做雙機 發布:2024-05-07 02:37:25 瀏覽:36
ftp剪切 發布:2024-05-07 02:37:14 瀏覽:138