國家計算機2級等級考試-C語言上機編程100題庫-必備_第1頁
國家計算機2級等級考試-C語言上機編程100題庫-必備_第2頁
國家計算機2級等級考試-C語言上機編程100題庫-必備_第3頁
國家計算機2級等級考試-C語言上機編程100題庫-必備_第4頁
國家計算機2級等級考試-C語言上機編程100題庫-必備_第5頁
已閱讀5頁,還剩39頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1:第1題m個人的成績存放在score數(shù)組中,請編寫函數(shù)fun,它的功能是:將低于平均分的人作為函數(shù)值返回,將低于平均分的分數(shù)放在below所指定的函數(shù)中。

答案:intfun(intscore[],intm,intbelow[])

{

inti,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++;

}

returnk;

}

2:第2題請編寫函數(shù)fun,它的功能是:求出1到100之內(nèi)能北7或者11整除,但不能同時北7和11整除的所有證書,并將他們放在a所指的數(shù)組中,通過n返回這些數(shù)的個數(shù)。

答案:voidfun(int*a,int*n)

{

inti,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題請編寫函數(shù)voidfun(intx,intpp[],int*n),它的功能是:求出能整除x且不是偶數(shù)的各整數(shù),并按從小到大的順序放在pp所指的數(shù)組中,這些除數(shù)的個數(shù)通過形參n返回。

答案:voidfun(intx,intpp[],int*n)

{

inti=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題請編寫一個函數(shù)voidfun(char*tt,intpp[]),統(tǒng)計在tt字符中"a"到"z"26各字母各自出現(xiàn)的次數(shù),并依次放在pp所指的數(shù)組中。

答案:voidfun(char*tt,intpp[])

{

inti;

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

pp[i]=0;

while(*tt)

{

switch(*tt)

{

case‘a(chǎn)’: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題請編寫一個函數(shù)voidfun(intm,intk,intxx[]),該函數(shù)的功能是:將大于整數(shù)m且緊靠m的k各素數(shù)存入xx所指的數(shù)組中。

答案:voidfun(intm,intk,intxx[])

{

intg=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題請編寫一個函數(shù)voidfun(chara[],char[],intn),其功能是:刪除以各字符串中指定下標的字符。其中,a指向原字符串,刪除后的字符串存放在b所指的數(shù)組中,n中存放指定的下標。

答案:voidfun(chara[],charb[],intn)

{

intI,j=0;

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

if(i!=n)

{

b[j]=a[i];

j++;

}

b[j]=‘\0’;

}

7:第7題請編寫一個函數(shù)intfun(int*s,intt,int*k),用來求除數(shù)組的最大元素在數(shù)組中的下標并存放在k所指的儲存單元中。

答案:voidfun(int*s,intt,int*k)

{

intI,max;

max=s[0];

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

if(s[i]>max)

{

max=s[i];

*k=I;

}

}

8:第8題編寫函數(shù)fun,功能是:根據(jù)以下攻勢計算s,計算結果作為函數(shù)值返回;n通過形參傳入。S=1+1/(1+2)+1/(1+2+3)+…….+1/(1+2+3+4+……+n)

答案:floatfun(intn)

{

inti;

floats=1.0,t=1.0;

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

{

t=t+i;

s=s+1/t;

}

returns;

}

9:第9題編寫一個函數(shù)fun,它的功能是:根據(jù)以下公式求p的值,結果由函數(shù)值帶回。M與n為兩個正整數(shù),且要求m>n。p=m!/n!(m-n)!

答案:floatfun(intm,intn)

{

floatp,t=1.0;

intI;

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;

returnp;

}

10:第10題編寫函數(shù)fun,它的功能是:利用以下的簡單迭代方法求方程cos(x)-x=0的一個實根。

迭代步驟如下:(1)取x1初值為0.0;(2)x0=x1,把x1的值賦各x0;

(3)x1=cos(x0),求出一個新的x1;

(4)假設x0-x1的絕對值小于0.000001,那么執(zhí)行步驟(5),否那么執(zhí)行步驟(2);

(5)所求x1就是方程cos(x)-x=0的一個實根,作為函數(shù)值返回。

程序?qū)⑤敵鰎oot=0.739085。

答案:floatfun()

{

floatx1=0.0,x0;

do

{

x0=x1;

x1=cos(x0);

}

while(fabs(x0-x1)>1e-6);

returnx1;

}

11:第11題以下程序定義了n×n的二維數(shù)組,并在主函數(shù)中自動賦值。請編寫函數(shù)fun(inta[][n]),該函數(shù)的功能是:使數(shù)組左下半三角元素中的值全部置成0。

答案:intfun(inta[][N])

{

intI,j;

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

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

a[i][j]=0;

}

12:第12題以下程序定義了n×n的二維數(shù)組,并在主函數(shù)中賦值。請編寫函數(shù)fun,函數(shù)的功能使求出數(shù)組周邊元素的平均值并作為函數(shù)值返回給主函數(shù)中的s。

答案:doublefun(intw[][N])

{

intI,j,k=0;

doubles=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++;

}

returns/=k;

}

13:第13題請編寫一個函數(shù)voidfun(inttt[m][n],intpp[n]),tt指向一個m行n列的二維函數(shù)組,求出二維函數(shù)組每列中最小元素,并依次放入pp所指定一維數(shù)組中。二維數(shù)組中的數(shù)已在主函數(shù)中賦予。

答案:voidfun(inttt[M][N],intpp[N])

{

intI,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題請別寫函數(shù)fun,函數(shù)的功能使求出二維數(shù)組周邊元素之和,作為函數(shù)值返回。二維數(shù)組中的值在主函數(shù)中賦予。

答案:intfun(inta[M][N])

{

intI,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];

}

returns;

}

15:第15題請編寫一個函數(shù)unsignedfun(unsignedw),w使一個大于10的無符號整數(shù),假設w使n(n≥2)位的整數(shù),那么函數(shù)求出w后n-1位的數(shù)作為函數(shù)值返回。

答案:unsignedfun(unsignedw)

{

unsignedt,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;

}

returns;

}

16:第16題請編寫一個函數(shù)floatfun(doubleh),函數(shù)的功能使對變量h中的值保存2位小樹,并對第三位進行四舍五入(規(guī)定h中的值位正數(shù))。

答案:floatfun(floath)

{

longt;

floats;

h=h*1000;

t=(h+5)/10;

s=(float)t/100.0;

returns;

}

17:第17題請編寫一個函數(shù)fun(char*s),該函數(shù)的功能使把字符串中的內(nèi)容擬置。

答案:voidfun(char*s)

{

charch;

intI,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題編寫程序,實現(xiàn)矩陣(3行3列)的轉置(即行列互換)。

答案:voidfun(intarray[3][3])

{

intI,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題編寫函數(shù)fun,該函數(shù)的功能是:從字符中刪除指定的字符,同一字母的大、小寫按不同字符處理。

答案:voidfun(chars[],intc)

{

inti=0;

char*p;

p=s;

while(*p)

{

if(*p!=c)

{

s[i]=*p;

i++;

}

p++;

}

s[i]=‘\0’;

}

20:第20題編寫函數(shù)intfun(intlim,intaa[max]),該函數(shù)的功能是求出小于或等于lim的所有素數(shù)并放在aa數(shù)組中,該函數(shù)返回所求的素數(shù)的個數(shù)。

答案:intfun(intlim,intaa[MAX])

{

intk=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++;

}

}

returnk++;

}

21:第21題請編寫函數(shù)fun,對長度位7個字符的字符串,除首尾字符外,將其余5個字符按ascii碼降序排列。

答案:voidfun(char*s,intnum)

{

chart;

intI,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名學生的成績已在主函數(shù)中放入一個帶頭節(jié)點的鏈表結構中,h指向鏈表的頭節(jié)點。請編寫函數(shù)fun,它的功能是:找出學生的最高分,由函數(shù)值返回。

答案:doublefun(STREC*h)

{

doublemax;

STREC*q=h;

max=h->s;

do

{

if(q->s>max)

max=q->s;

q=q->next;

}

while(q!=0);

returnmax;

}

23:第23題請編寫函數(shù)fun,該函數(shù)的功能是:判斷字符串是否為回文?假設是那么函數(shù)返回1,主函數(shù)中輸出yes,否那么返回0,主函數(shù)中輸出no。回文是指順讀和倒讀都是一樣的字符串。

答案:intfun(char*str)

{

intI,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;

}

returnfg;

}

24:第24題請編寫一個函數(shù)fun,它的功能是:將一個字符串轉換為一個整數(shù)(不得調(diào)用c語言提供的將字符串轉換為整數(shù)的函數(shù))。

答案:longfun(char*p)

{

longs=0,t;

inti=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

returns;

}

25:第25題請編寫一個函數(shù)fun,它的功能是:比擬兩個字符串的長度,(不得調(diào)用c語言提供的求字符串長度的函數(shù)),函數(shù)返回較長的字符串。假設兩個字符串長度相同,那么返回第一個字符串。

答案:char*fun(char*s,char*t)

{

char*p,*t1=t,*s1=s;

intn=0;m=0;

while(*s1)

{

n++;

s1++;

}

while(*t1)

{

m++;

t1++;

}

if(n>=m)

p=s;

else

p=t;

returnp;

}

26:第26題請編寫一個函數(shù)fun,它的功能是:根據(jù)以下公式求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…。

答案:doublefun(doubleeps)

{

doubles;

floatn,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;

returnpi;

}

27:第27題請編寫一個函數(shù)fun,它的功能是:求除1到m之內(nèi)(含m)能北7或11整除的所有整數(shù)放在數(shù)組a中,通過n返回這些數(shù)的個數(shù)。

答案:voidfun(intm,int*a,int*n)

{

intI,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題請編寫一個函數(shù)fun,它的功能是:找出一維整型數(shù)組元素中最大的值和它所在的下標,最大的值和它所在的下標通過形參傳回。數(shù)組元素中的值已在主函數(shù)中賦予。主函數(shù)中x是數(shù)組名,n是x中的數(shù)據(jù)個數(shù),max存放最大值,index存放最大值所在元素的下標。

答案:voidfun(inta[],intn,int*max,int*d)

{

intI;

*max=a[0];

*d=0;

for(i=0;I<n;i++)

if(a[i]>*max)

{

*max=a[i];

*d=I;

}

}

29:第29題請編寫一個函數(shù)fun,它的功能是:將ss所指字符串中所有下標為奇數(shù)位置上的字母轉換為大寫(假設該位置上不是字母,那么不轉換)。

答案:voidfun(char*ss)

{

intI,n;

n=strlen(ss);

for(i=1;i<n;i+=2)

if(ss[i]>=‘a(chǎn)’&&ss[i]<=‘z’)

ss[i]=ss[i]-32;

}

30:第30題請編寫一個函數(shù)fun,它的功能是:求除一個2×m整型二維數(shù)組中最大元素的值,并將此值返回調(diào)用函數(shù)。

答案:intfun(inta[][M])

{

intI,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];

returnmax;

}

31:第31題請編寫函數(shù)fun,其功能是:將s所指字符串中除了下標為偶數(shù)、同時ascii值也為偶數(shù)的字符外,其余的全都刪除;串中剩余字符所形成的一個新串放在t所指的一個數(shù)組中。

答案:voidfun(char*s,chart[])

{

intI,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題請編寫函數(shù)fun,其功能是:將s所指字符串中除了下標為奇數(shù)、同時ascii值也為奇數(shù)的字符之外,其余的所有字符都刪除,串中剩余字符所形成的一個新串放在t所指的一個數(shù)組中。

答案:voidfun(char*s,chart[])

{

intI,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題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:使字符串中尾部的*號不得多于n個;假設多于n個,那么刪除多于的*號;假設少于或等于n個,那么什么也不做,字符串中間和前面的*號不刪除。

答案:voidfun(char*a,intn)

{

inti=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名學生的數(shù)據(jù)已在主函數(shù)中放入結構體數(shù)組s中,請編寫函數(shù)fun,它的功能使:把分數(shù)最高的學生數(shù)據(jù)放在h所指的數(shù)組中,注意:分數(shù)最高的學生可能不止一個,函數(shù)返回分數(shù)最高的學生的人數(shù)。

答案:intfun(STREC*a,STREC*b)

{

intI,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++;

}

returnn;

}

35:第35題請編寫一個函數(shù),用來刪除字符串中的所有空格。

答案:voidfun(char*str)

{

inti=0;

char*p=str;

while(*p)

{

if(*p!=‘’)

{

str[i]=*p;

i++;

}

p++;

}

str[i]=‘\0’;

}

36:第36題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:將字符串中的前導*號全部移到字符串的尾部。

答案:voidfun(char*a)

{

inti=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門課程的成績已在主函數(shù)中給出。請編寫函數(shù)fun,它的功能是:求出該學生的平均分放在記錄的ave成員中。請自己定義正確的形參。

答案:voidfun(STREC*p)

{

doubleav=0.0;

inti:

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

av+=p->s[i];

av/=N;

p->ave=av;

}

38:第38題請編寫函數(shù)fun,它的功能是:求出ss所指字符串中指定字符的個數(shù),并返回此值。

答案:intfun(char*ss,charc)

{

intn=0;

while(*ss)

{

if(*ss==c)

n++;

ss++;

}

returnn;

}

39:第39題請編寫函數(shù)fun,該函數(shù)的功能是:移動一維數(shù)組中的內(nèi)容,假設數(shù)組中由n個整數(shù),要求把下標從0到p(p小于等于n-1)的數(shù)組元素平移到數(shù)組的最后。

答案:voidfun(int*w,intp,intn)

{

intb[N],i,j=0;

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

{

b[i]=w[i];

j++;

}

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

{

w[j]=b[i];

j++;

}

}

40:第40題請編寫函數(shù)fun,該函數(shù)的功能是移動字符串中內(nèi)容,移動的規(guī)那么如下:把第1到第m個字符,平移到字符串的最后,把第m+1到最后的字符移到字符串的前部。

答案:voidfun(char*w,intm)

{

charb[N];

intI,j=0;

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

{

b[j]=w[i];

j++;

}

for(i=0;i<strlen(w)-m;i++)

w[i]=w[i+m];

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

{

w[i]=b[j];

i++;

}

w[i]=‘\0’;

}

41:第41題請編寫函數(shù)fun,該函數(shù)的功能是:將m行n列的二維數(shù)組中的字符數(shù)據(jù),按列的順序依次放到一個字符串中。

答案:voidfun(char(*s)[n],char*b)

{inti,j,k=0;

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

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

{b[k]=*(*(s+i)+j)

k++;}

b[k]=‘\0’;}

42:第42題以下程序定義了n×n的二維數(shù)組,并在主函數(shù)中自動賦值。請編寫函數(shù)fun(inta[][n],intn),該函數(shù)的功能是:將數(shù)組右上半三角元素中的值乘以m。

答案:voidfun(inta[][n],intm)

{inti,j;

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

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

a[j]=a[j]*m;}

43:第43題編寫一個函數(shù),從傳入的num個字符串中找出一個最長的一個字符串,并通過形參指針max傳回該串地址(用****作為結束輸入的標志)。

答案:char*fun(char(*a)[81],intnum)

{inti;

char*max;

max=a[0];

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

if(strlen(max)<strlen(a))

max=a;

returnmax;}

44:第44題編寫一個函數(shù),該函數(shù)可以統(tǒng)計一個長度為2的字符串在另一個字符串中出現(xiàn)的次數(shù)。

答案:intfun(char*str,char*substr)

{intn;

char*p,*r;

n=0;

while(*str)

{p=str;

r=substr;

while(*r)

if(*r==*p)

{r++;

p++;}

else

break;

if(*r==‘\0’)

n++;

str++;}

returnn;}

45:第45題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:只刪除字符串前導和尾部的*號,串中字母之間的*號都不刪除。形參n給出了字符串的長度,形參h給出了字符串中前導*號的個數(shù),形參e給出了字符串中最后的*個數(shù)。在編寫時不得使用c語言給提供得字符串函數(shù)。

答案:voidfun(char*a,intn,inth,inte)

{inti=0;

char*p;

for(p=a+h;p<a+n-e;p++)

{*(a+i)=*p;

i++;}

*(a+i)=‘\0’;}

46:第46題學生得記錄由學號和成績組稱個,n名大學生得數(shù)據(jù)已在主函數(shù)中放入結構體數(shù)組s中,請編寫函數(shù)fun,它的功能時:按分數(shù)的上下排列學生的記錄,高分在前。

答案:voidfun(streca[])

{inti,j;

strect;

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

for(j=i;s<n;j++)

if(a.s<a[j].s)

{t=a;

a=a[j];

a[j]=t;}}

47:第47題請編寫一個函數(shù)voidfun(char*ss),其功能時:將字符串ss中所有下標為奇數(shù)位置上的字母轉換為大寫(假設位置上不是字母,那么不轉換)。

答案:voidfun(char*ss)

{inti,n=0;

char*p=ss;

while(*p)

{n++;

p++;}

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

if((ss=‘a(chǎn)’&ss<=‘z’)&i%2!=0)

ss=ss-32;

ss=‘\0’;}

48:第48題請編寫函數(shù)fun,其功能是:將兩個兩位數(shù)的正整數(shù)a,b合并成一個整數(shù)放在c中。合并的方式是:將a數(shù)的十位和個位依次放在c數(shù)的千位和十位上,b數(shù)的十位和個位數(shù)依次放在c數(shù)的百位和個位上。

答案:voidfun(inta,intb,long*c)

{*c=(a/10)*1000+(b/10)*100+(a%10)*10+b%10;}

49:第49題請編寫函數(shù)fun,其功能是:將s所指字符串中下標位偶數(shù)同時ascii值為奇數(shù)的字符刪除,s中剩余的字符形成的新串放在t所指的數(shù)組中。

答案:voidfun(char*s,chart[])

{inti,j=0,n=strlen(s);

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

if(i%2==0&s%2!=0)

else

{f[j]=s;

j++;}

t[j]=‘\0’;}

50:第50題學生的記錄是由學號和學習成績構成,n名學生的數(shù)據(jù)已存入a機構體數(shù)組中。請編寫函數(shù)fun,該函數(shù)的功能是:找出成績最高的學生記錄,通過形參返回主函數(shù)(規(guī)定只有一個最高分)。

答案:voidfun(stua[],stu*s)

{inti,max;

max=a[0].s;

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

if(a.s>max)

{max=a.s;

*s=a;}}51:第51題請編寫函數(shù)fun,其功能是:將所有大于1小于整數(shù)m的非素數(shù)存入xx所指的數(shù)組中,非素數(shù)的個數(shù)通過k傳回。答案:voidfun(intm,int*k,intxx[]){inti,j;intt=0;for(i=2;i<m;i++){j=2;while(j<i){if(i%j==0){xx[t]=i;t++;break;}j++;}*k=t;}}52:第52題編寫一個函數(shù)fun,它的功能是:實現(xiàn)兩個字符串的連接(不使用庫函數(shù)strcat),即把p2所指的字符串連接到p1所指的字符串后。答案:voidfun(charp1[],charp2[]){inti=0,n=0;char*p=p1,*q=p2;while(*p){p++;n++;}i=n;while(*p){p1=*q;q++;i++;}p1=‘\0’;}53:第53題請編寫函數(shù)fun,該函數(shù)的功能是:實現(xiàn)b=a+a,即把矩陣a加上a的轉置,存放在矩陣b中。計算結果在main函數(shù)中輸出。答案:voidfun(inta[3][3],intb[3][3]){inti,j,at[3][3];for(i=0;i<=2;i++)for(j=0;j<=2;j++)at[j]=a[j];for(i=0;i<3;i++)for(j=0;j<3;j++)b[j]=a[j]+at[j];}54:第54題學生的記錄由學號和成績組稱個,n名學生的數(shù)據(jù)已在主函數(shù)中放入結構體數(shù)組s中,請編寫函數(shù)fun,它的功能是:把低于平均分的學生數(shù)據(jù)放在b所指的數(shù)組中,低于平均分的學生人數(shù)通過形參n傳回,平均分通過函數(shù)值返回。答案:doublefun(strec*a,strec*b,int*n){doubleaver=0.0;inti,j=0;*n=0;for(i=0;i<n;i++)aver+=a.s;aver/=n;for(i=0;i<n;i++)if(a.s<aver){b[j]=a;(*n)++;j++;}returnaver;}55:第55題請編寫函數(shù)fun,該函數(shù)的功能是:將m行n列的二維數(shù)組中的數(shù)據(jù),按行的順序依次放到一維數(shù)組中,一維數(shù)組中數(shù)據(jù)的個數(shù)存放在形參n所指的儲存單元中。答案:voidfun(int(*s)[10],int*b,int*n,intmm,intnn){inti,j;for(i=0;i<mm;i++)for(j=0;j<nn;j++){b[*n]=*(*(s+i)+j);*n=*n+1;}}56:第56題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:除了尾部的*號之外,將字母串中其他*號全部刪除。形參p已指向字符串中最后的一個字母。不使用c的字符串函數(shù)。答案:voidfun(char*a,char*p){inti=0;char*p=a;while(q<=p){if(*q!=‘*’){a=*q;i++;}q++;}while(*q){a=*q;i++;q++;}a=‘\0’;}57:第57題學生的記錄是由學號和成績組成,n名學生的數(shù)據(jù)已在主函數(shù)中放入結構體數(shù)組s中,請編寫函數(shù)fun,它的功能是:把指定分數(shù)范圍內(nèi)的學生數(shù)據(jù)放在b所指的數(shù)組中,分數(shù)范圍內(nèi)的學生人數(shù)由函數(shù)值返回。答案:intfun(strec*a,strec*b,intl,inth){inti,j=0;for(i=0;i<n;i++)if(a.s>=l&a.s<=h){b[j]=a;j++;}returnj;}58:第58題編寫函數(shù)藏服那,它的功能是:求n以內(nèi)(不包括n)同時能被3與7整除的所有自然數(shù)之和的平方根s,并作為函數(shù)值返回。答案:doublefun(intn){doubles=0.0;inti;for(i=1;i<n;i++)if(i%3==0&i%7==0)s=s+i;s=sqrt(s);returns;}59:第59題請別寫函數(shù)fun,該函數(shù)的功能是:將放在字符串數(shù)組中的m個字符串(每串的長度不超過n),按順序合并組成一個新的字符串。答案:voidfun(chara[m][n],char*b){inti,j,k=0;for(i=0;i<m;i++){for(j=0;j<n;j++)if(*(*(a+i)+j)){b[k]=*(*(a+i)+j)k++;}elsebreak;b[k]=‘\0’;}}60:第60題請編寫函數(shù)fun,該函數(shù)的功能是:刪去一維數(shù)組中所有相同的數(shù),使之只剩一個。數(shù)組中的數(shù)已按由小到大的順序排列,函數(shù)返回刪除后數(shù)組中數(shù)據(jù)的個數(shù)。答案:intfun(inta[],intn){inti,t,j=0,*p=a;t=p[0];for(i=0;i<=n;i++)if(t==p);else{a[j]=t;t=p;j++;}if(i>=n)a[j]=t;returnj;}61:第61題第請編寫函數(shù)fun,該函數(shù)的功能使:統(tǒng)計各年齡段的人數(shù)。N個年齡通過調(diào)用隨機函數(shù)獲得,并放在主函數(shù)的age數(shù)組中;要求函數(shù)把0至9歲年齡段的人數(shù)放在d[0]中,把10至19歲年齡段的人數(shù)放在d[1]中,把20至29歲的人數(shù)放在d[2]中,其余以此類推,把100歲(含100以上年齡的人數(shù)都放在d[10]中。結果在主函數(shù)中輸出。答案:voidfun(int*a,int*b){inti,j;for(j=0;i<m;j++)b[j]=0;for(i=0;i<n;i++)if(a>=0&a<=9)b[0]+=1;elseif(a>=10&a<=19)b[1]+=1;elseif(a>=20&a<=29)b[2]+=1;elseif(a>=30&a<=39)b[3]+=1;elseif(a>=40&a<=49)b[4]+=1;elseif(a>=50&a<=59)b[5]+=1;elseif(a>=60&a<=69)b[6]+=1;elseif(a>=70&a<=79)b[7]+=1;elseif(a>=80&a<=89)b[8]+=1;elseif(a>=90&a<=99)b[9]+=1;elseb[10]+=1;}62:第62題請編寫函數(shù)fun,該函數(shù)的功能是:統(tǒng)一一含字符串中單詞的個數(shù),作為函數(shù)值返回。一行字符串在主函數(shù)中輸入,規(guī)定所有單詞由小寫字母組成,單詞之間由假設干個空格格開,一行的開始沒有空格。答案:intfun(char*s){inti,n=0;for(i=0;i<strlen(s);i++){if(s=‘a(chǎn)’&s<=‘z’&s[i+1]==‘’‖s[i+1]==‘\0’)n++;}returnn;}63:第63題請編寫一個函數(shù)fun,它的功能是:計算并輸出給定整數(shù)n的所有因子(不包括1與自身)之和。規(guī)定n的值不大于1000。答案:intfun(intn){ints=0,i;for(i=2;i<=n-1;i++)if(n%i==0)s+=i;returns;}64:第64題請編寫函數(shù)fun,其功能是:將s所指字符串中ascii值為奇數(shù)的字符刪除,串中剩余字符形成一個新串放在t所指的數(shù)組中。答案:voidfun(char*s,chart[]){inti,j=0,n;n=strlen(s);for(i=0;i<n;i++)if(s%2==0){t[j]=s;j++;}t[j]=‘\0’;}65:第65題請編寫函數(shù)fun,其功能是:將兩位數(shù)的正整數(shù)a、b合并成一個整數(shù)放在c中。合并的方式是:將a數(shù)的十位和個位數(shù)依次放在c數(shù)的百位和個位上,b數(shù)的十位和個位數(shù)依次放在c數(shù)的十位和千位上。答案:voidfun(inta,intb,long*c){*c=(b%10)*1000+(a/10)*100+(b/10)*10+a%10;}66:第66題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:刪除字符串中所有*號。在編寫函數(shù)時,不得使用c語言提供的字符串函數(shù)。答案:voidfun(char*a){inti=0;char*p=a;while(*p){if(*p!=‘*’){a=*p;i++;}p++;}a=‘\0’;}67:第67題學生的記錄時由學號和成績組成,n名學生的數(shù)據(jù)已在主函數(shù)中放入結構體數(shù)組s中,請編寫函數(shù)fun,它的功能時:函數(shù)返回指定學號的學生數(shù)據(jù),指定的學號在主函數(shù)中輸入。假設沒找到指定學號,在結構體變量中給學號置空串,給成績置-1,作為函數(shù)值返回(用于字符串比擬的函數(shù)時strcmp)。答案:strecfun(strec*,char*b){inti;strech;for(i=0;i<n;i++)if(strcmp(a.num,b)==0){h=a;break;}else{h.num=="";h.s=-1;}returnh;}68:第68題請編寫函數(shù)fun,其功能時:計算并輸出以下多項式的值:sn=1+1/1!+1/2!+1/3!+1/4!+…+1/n!答案:sn=1+1/1!+1/2!+1/3!+1/4!+...+1/n!doublefun(intn){doublet,sn=1.0;inti,j;for(i=1;i<n;i++){t=1.0;for(j=1;j<=i;j++)t*j;;}returnsn;}69:第69題請編寫一個函數(shù)fun,它的功能時:求fibonacci數(shù)列中大于t的最小的一個數(shù),結果由函數(shù)返回。其中fibonacci數(shù)列f(n)的定義為:f(0)=0,f(1)=1,f(n)=f(n-1)+f(n-2)答案:f(0)=0,f(1)=1,f(n)=f(n-1)+f(n-2)intfun(intt){inta=1,b=1,c=0,i;for(i=4;i<=t;i++){if(c<t){c=a+b;a=b;b=c;}elsebreak;}returnc;}70:第70題編寫函數(shù)fun,它的功能時:計算并輸出以下級數(shù)和:s=1/1*2+1/2*3+…+1/n(n+1)答案:doublefun(intn){doubles=0.0;inti;for(i=1;i<=n;i++)s=s+1.0/(i*(i+1));returns;}71:第71題請編寫函數(shù)fun,其功能時:將兩個兩位數(shù)的正整數(shù)a、b合并形成一個整數(shù)放在c中,合并的方式是:將a數(shù)的十位和個位數(shù)依次放在c數(shù)的十位和千位上,b的十位和個位整數(shù)依次放在c數(shù)的百位和個位上。答案:voidfun(inta,intb,long*c){*c=(a%10)*1000+(b/10)*100+(a/10)*10+b%10;}72:第72題請編寫函數(shù)fun,其功能是:將s所指字符串中下標為偶數(shù)的字符刪除,串中剩余字符形成新串放在t所指數(shù)組中。答案:voidfun(char*s,chart[]){inti,j=0,n=strlen(s);for(i=0;i<n;i++)if(i%2!=0){t[j]=s;j++;}t[j]=‘\0’;}73:第73題假定輸入的字符串中只包含字母和*號,請編寫函數(shù)fun,它的功能是:除了字符串前導和尾部的*號之外,將串中其他*號全部刪除。形參h已指向字符串第一個字符,形參p已指向字符串中最后一個字母。在編寫程序時,不得使用c語言提供的字符串函數(shù)。答案:voidfun(char*a,char*h,char*p){inti=0;char*q=a;while(q<h){a=*q;q++;i++;}while(q<p){if(*q!=‘’*){a=*q;i++;}q++;}while(*q){a=*q;i++;q++;}a=‘\0’;}74:第74題學生的記錄由學號和成績組成n名學生的數(shù)據(jù)已在主函數(shù)中放入結構體數(shù)組s中,請編寫函數(shù)fun,它的功能時:把分數(shù)最低的學生數(shù)據(jù)放在h所指的數(shù)組中,注意:分數(shù)最低的學生可能不止一個,函數(shù)返回分數(shù)最低的學生的人數(shù)。答案:intfun(strec*a,strec*b){inti,j=0,n=0,min;min=a[0].s;for(i=0;i<n;i++)if(a.s<min)min=a.s;for(i=0;i<n;i++)if(a.s==min){*(b+j)=a;j++;n++;}returnn;}75:第75題請編寫函數(shù)fun,該函數(shù)的功能:將m行n列的二維數(shù)組中的數(shù)據(jù),按列的順學依次放到一維數(shù)組中。答案:voidfun(int(*s)[]10,int*b,int*n,intmm,intnn){inti,j;for(j=0;j<nn;j++)for(i=0;i<mm;i++){b[*n]=*(*(s+i)+j);*n=*n+1;}}76:第76題請編寫函數(shù)fun,其功能時:計算并輸出當x<0.97時以下多項式的值,直到|sn-s(n-1)|<0.000001為止。Sn=1+0.5x+0.5(0.5-1)/2!x(2)+…+0.5(0.5-1)(0.5-2)…..(0.5-n+1)/n!x(n)答案:.doublefun(doublex){doubles1=1.0,p=1.0,sum=0.0,s0,t=1.0;intn=1;do{s0=s1;sum+=s0;t*=n;p*=(0.5-n+1)*x;s1=p/t;n++;}while(fabs(s1-s0)>1e-6);returnsum;}77:第77題請編寫一個函數(shù)fun,其功能是:將兩個兩位數(shù)的正整數(shù)ab合并形成一個整數(shù)放在c中。合并方式是:將a數(shù)的十位和個位數(shù)依次放在c數(shù)的個位和百位上,b數(shù)的十位和個位數(shù)依次放在c數(shù)的十位和千位上。答案:voidfun(inta,intb,long*c){*c=(b%10)*1000+(a%10)*100+(b/10)*10+a/10;}78:第78題請編寫函數(shù)fun,其功能是:將s所指字符串中ascii值為偶數(shù)的字符刪除,串中剩余字符形成一個新串放在t所指的數(shù)組中。答案:voidfun(char*s,chart[]){inti,j=0,n=strlen(s);for(i=0;i<n;i++)if(s%2!=0){t[j]=s;j++;}t[j]=‘\0’;}79:第79題學生的記錄由學號和學習成績構成,n名學生的數(shù)據(jù)已存入a結構體數(shù)組中。請編寫函數(shù)fun,該函數(shù)的功能是:找出成績最低的學生記錄,通過形參返回主函數(shù)(規(guī)定只有一個最低分)。答案:voidfun(stua[],stu*s){inti,min;min=a[0].s;for(i=0;i<n;i++)if(a.s<min){min=a.s;*s=a;}}80:第80題程序定義了n×n的二維數(shù)組,并在主函數(shù)中自動賦值。請編寫函數(shù)fun,該函數(shù)的功能是:使數(shù)組左下半三角元素中的值乘以n。答案:fun(inta[][n],intn){inti,j;for(i=0;i<n;i++)for(j=0;j<=i;j++)a[j]=a[j]*n;}81:第81題請編寫函數(shù)fun,其功能使:將兩個兩位正整數(shù)ab合并形成一個整數(shù)放在c中。合并的方式使:將a數(shù)的十位和個位數(shù)依次放在c數(shù)的百位和個位上,b數(shù)的十位和個位數(shù)依次放在c數(shù)的千位和十位上。答案:voidfun(inta,intb,long*c){*c=(b/10)*1000+(a/10)*100+(b%10)*10+a%10;}82:第82題請編寫一個函數(shù)fun,它的功能使:計算n門課程的平均分,計算結果作為函數(shù)值返回。答案:floatfun(float*a,intn){floatave=0.0;inti;for(i=0;i<n;i++)ave+=a;ave/=n;returnave;}83:第83題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能使:將字符串尾部的*號全部刪除,前面和中間的*號不刪除。答案:voidfun(char*a){inti=0;char*p,*q;p=q=a;while(*p)p++;p--;while(*p==‘*’)p--;while(q<=p){a=*q;i++;q++;}a=‘\0’;}84:第84題請編寫函數(shù)fun,其功能是:將兩個兩位數(shù)的正整數(shù)ab合并形成一個整數(shù)放在c中,合并的方式是:將a數(shù)的十位和個位數(shù)依次放在c的個位和百位上,b數(shù)的十位和個位數(shù)依次放在c數(shù)的千位和十位上。答案:voidfun(inta,intb,long*c){c=(b/10)*1000+(a%10)*100+(b%10)*10+a/10;}85:第85題n名學生的成績已在主函數(shù)中放入一個帶頭節(jié)點的鏈表結構中,h指向鏈表的頭節(jié)點。請編寫函數(shù)fun,它的功能是:求出平均分,由函數(shù)值返回。答案:doublefun(strec*h){doubleaver=0.0;while(h!=null){aver+=h->s;hy=h->next;}aver/=n;returnaver;}86:第86題請編寫函數(shù)fun,計算并輸出給定10個數(shù)的方差。答案:doublefun(doublex[10]){inti,j;,s1=0.0;for(i=0;i<10;i++)s1+=x;s1/=10;for(j=0;j<10;j++)s+=(x[j]-s1)*(x[j]-s1);s/=10;s=pow(s,0.5);returns;}87:第87題請編寫函數(shù)fun,其功能是:將兩個兩位數(shù)的正整數(shù)ab合并形成一個整數(shù)放在c中。合并的方式是:將a數(shù)的十位和個位數(shù)依次放在c數(shù)的千位和十位上,b數(shù)的十位和個位數(shù)依次放在c數(shù)的個位和百位上。答案:voidfun(inta,intb,long*c){*c=(a/10)*1000+(a%10)*10+(b%10)*100+b/10;}88:第88題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:除了字符串前導的*號之外,將串中其他*號全部刪除。在編寫函數(shù)亞時,不得使用c語言提供的字符串函數(shù)。答案:voidfun(char*a){inti=0;char*p=a;while(*p&&*p==‘*’){a=*p;i++;p++;}while(*p){if(*p!=‘*’){a=*p;i++;}p++;}a=‘\0’;}89:第89題學生的記錄是由學號和成績組成,n名學生的數(shù)據(jù)已在主函數(shù)中放入結構體數(shù)組s中,請編寫函數(shù)fun,它的功能是:把高于等于平均分的學生數(shù)據(jù)放在b所指的數(shù)組中,高于等于平均分的學生人數(shù)通過形參n傳回,平均分通過函數(shù)值返回。答案:doublefun(strec*a,strec*b,int*n){doubleaver=0.0;inti,j=0;for(i=0;i<n;i++)aver+=a.s;aver/=n;for(i=0;i<n;i++)if(a.s)>=aver}{*(b+j)=a;j++;}*n=j;returnaver;}90:第90題請編寫函數(shù)fun,其功能是:計算并輸出以下多項式值:sn=(1-1/2)+(1/3-1/4)+…+(1/(2n-1)1/2n).答案:sn=(1-1/2)+(1/3-1/4)+...+(1/(2n-1)1/2n).doublefun(intn){inti;doublesn=0.0;for(i=1;i<=n;i++)sn+=(1.0/(2*i-1)-1.0/(2*i));returnsn;}91:第91題請編寫函數(shù)fun,其功能是:將兩個兩位數(shù)的正整數(shù)ab合并形成一個整數(shù)放在c中。合并的方式是:將a數(shù)的十位和個位數(shù)依次放在c的十位和千位上,b數(shù)的十位和個位數(shù)依次放在c數(shù)的個位和百位上。答案:voidfun(inta,intb,long*c){*c=(a%10)*1000+(b%10)*100+(a/10)*10+b/10;}92:第92題請編寫函數(shù)fun,它的功能是計算:s=(ln(1)+ln(2)+ln(3)+…+ln(m))(0.5),s作為函數(shù)值返回。答案:doublefun(intm){intI;doubles=0.0,log(doublex);for(i=1;i<=m;i++)s=s+log(i);s=sqrt(s);returns;}93:第93題請編寫函數(shù)fun,它的功能是計算以下級數(shù)和,和值由函數(shù)值返回。S=1+x+x(2)/2!+x(3)/3!+…x(n)/n!答案:doublefun(doublex,intn){doubles=1.0,p=1.0;intI,j,t;for(i=1;i<=n;i++){t=1;for(j=1;j<=i;j++)t=t*j;p=p*x;s=s+p/t;}returns;}94:第94題規(guī)定輸入字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:將函數(shù)字符串中的前導*號全部刪除,中間和尾部的*號不刪除。答案:voidfun(char*a){inti=0;char*p=a;while(*p&&*p==‘*’)p++;while(*p){a[i]=*p;i++;p++;}a[i]=‘\0’;}95:第95題假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能是:使字符串的前導*號不得多于n個;假設多于n個,那么刪除多于的*號;假設少于或等于n個,那么什么也不做。字符串中間和尾部的*號不刪除。答案:voidfun(char*a,intn){inti=0,k=0;char*t=a;while(*t==‘*’){k++;t++;}t=a;if(k>n)t=a+k-n;while(*t){a[i]=*t;i++;t++;}a[i]=‘\0’;}96:第96題請編寫函數(shù)fun,其功能使:計算并輸出給定數(shù)組(長度為9)中每相鄰兩個元素之平均值的平方根之和。答案:doublefun(doublex[9]){doublesum=0.0;intI,j=1;for(i=0;i<9;i++)if(j<=8){sum+=sqrt((x[i]+x[i+1])/2.0);j++;}returnsum;}97:第97題請編寫函數(shù)fun,其功能是:計算并輸出以下多項式值:s=1+1/(1+2)+1/(1+2+3)+..1/(1+2+3…+50)答案:doublefun(intn){intI,j;doublesum=0.0,t;for(i=1;i<=n;i++){t=0.0;for(j=1;j<=I;j++)t+=j;sum+=1.0/t;}returnsum;}98:第98題請編寫函數(shù)fun,它的功能是:計算并輸出n(包括n)以內(nèi)能被5或9整除的所有自然數(shù)的倒數(shù)之和。答案:doublefun(intn){intI;doublesum=0.0;for(i=1;i<=n;i++)if(i%5==0||i%9==0)sum+=1.0/I;returnsum;}99:第99題請編寫函數(shù)fun,其功能是:計算并輸出3到n之間所有素數(shù)的平方根之和。答案:doublefun(intn){intm,k,I;doubles=0.0;for(m=3;m<=n;m++){k=sqrt(m);for(i=2;i<=k;i++)if(m%i==0)break;if(i>=k+1)s+=sqrt(m);}returns;}100:第100題請編寫函數(shù)fun,其功能是:計算并輸出s=1+(1+2(0.5))+(1+2(0.5)+3(0.5))+…+(1+2(0.5)+3(0.5)+…+n(0.5))答案:doublefun(intn){intI;double=1.0,p=1.0;for(i=2;i<=n;i++){p+=pow(I,0.5);s+=p;}returns;}C語言筆試考點【考點1】C程序用C語言編寫的程序稱為C語言源程序,源程序文件的后綴名為“.c〞。源程序經(jīng)編譯后生成后綴名為“.obj〞的目標文件,再把目標文件與各種庫函數(shù)連接起來,生成“.exe〞可執(zhí)行文件。C語言有三種根本結構:順序結構、選擇結構、循環(huán)結構?!究键c2】main函數(shù)又稱主函數(shù),是C程序的入口。main后面跟一對小括號和一對花括號,花括號括起來的局部稱為main函數(shù)的函數(shù)體。一個C程序從main函數(shù)開始執(zhí)行,到main函數(shù)體執(zhí)行完結束,而不管main函數(shù)在整個程序中的位置如何。每一個程序有且僅有一個main函數(shù),其他函數(shù)都是為main函數(shù)效勞的?!究键c3】存儲形式計算機在電腦中保存數(shù)據(jù)是采用二進制形式,由0或1構成的二進制稱為位〔bit〕,八個位構成一個字節(jié)〔Byte〕,1個Byte=8個bit。二進制、八進制、十六進制轉化為十進制采用乘法,十進制轉化為二進制、八進制、十六進制采用除法。數(shù)據(jù)的存放位置就是它的地址?!究键c4】注釋是對程序的說明,可出現(xiàn)在程序中任意適宜的地方,注釋從“/*〞開始到最近一個“*/〞結束,其間任何內(nèi)容都不會被計算機執(zhí)行,注釋不可以嵌套。【考點5】書寫格式每條語句的后面必須有一個分號,分號是語句的一局部。一行內(nèi)可寫多條語句,一個語句可寫在多行上?!究键c6】標識符是標識名字的有效字符序列,可以理解為C程序中的單詞。標識符的命名規(guī)那么是:〔1〕標識符只能由字母、數(shù)字和下劃線組成,字母區(qū)分大小寫?!?〕標識符的第一個字符必須是字母或下劃線,不能為數(shù)字。C語言標識符分如下3類〔1〕關鍵字。它們在程序中有固定的含義,不能另作他用。如int、for、switch等?!?〕預定義標識符。預先定義并具有特定含義的標識符。如define、include等?!?〕用戶標識符。用戶根據(jù)需要定義的標識符,符合命名規(guī)那么且不與關鍵字相同?!究键c7】常量與變量常量是指在程序運行過程中,其值不能改變的量。常量分為整型常量、實型常量、字符常量、字符串常量、符號常量5種。在程序運行過程中其值可以改變的量稱為變量。C語言中沒有字符串變量。存放字符串使用字符數(shù)組?!究键c8】整型數(shù)據(jù)整型常量有十進制、八進制、十六進制三種表示形式,沒有二進制形式。八進制整型常量加前導數(shù)字0,十六進制常量加前導0X,八進制常量中不會出現(xiàn)8。整型變量可分為根本整型〔int〕、短整型〔short〕、長整型〔long〕、和無符號整型〔unsigned〕。一個根本整型占4個字節(jié)。其它類型的整型占用字節(jié)數(shù)和取值范圍詳見教材第9頁?!究键c9】實型數(shù)據(jù)實型數(shù)據(jù)有兩種表示形式:小數(shù)形式和指數(shù)形式。掌握判定指數(shù)形式合法性??谠E:E前E后必有數(shù),E后必須為整數(shù)。實型變量分為單精度型〔float〕和雙精度型〔double〕,單精度型占四個字節(jié)?!究键c10】算術運算算術運算符一共有+、—、*、/、%這五個。求余運算要求運算對象只能為整型,除法運算符兩邊運算對象都為整型時,運算結果也為整型即舍掉小數(shù)局部?!究键c11】強制類型轉換將一個運算對象轉換成指定類型,格式為〔類型名〕表達式,注意小括號位置?!究键c12】賦值賦值運算符為“=〞,不同于關系等于“==〞。賦值表達式格式為:變量名=表達式,賦值運算符左邊必須為變量,賦值運算是把賦值運算符右邊表達式的值賦給左邊變量。復合賦值運算符是將算術運算符或位運算符與賦值運算符組合在一起組成的運算符,掌握復合賦值表達式轉化為賦值表達式的方法。如n+=100可轉化為n=n+100?!究键c13】自加自減運算自加運算符“++〞與自減運算符“--〞是單目運算符,運算對象必須是變量。自增自減運算分前綴運算和后綴運算,它們所對應的表達式的值是有區(qū)別的,如j=i++;等價于j=i;i=i+1;而j=++i;等價于i=i+1;j=i;??谠E:加加在前先加后用,加加在后先用后加。【考點14】逗號運算逗號運算符運算優(yōu)先級最低,可將多個表達式構成一個新的表達式。第二章順序結構【考點1】運算符、表達式、語句運算對象加運算符構成表達式,表達式加分號構成表達式語句,運算對象可以是表達式、常量、變量。如賦值運算符加運算對象構成賦值表達式,賦值表達式加分號又可構成賦值語句?!究键c2】運算符的優(yōu)先級和結合順序運算符按參加運算的對象數(shù)目可分為單目運算符、雙目運算符和三目運算符。初等運算符的優(yōu)先級別最高,然后依次是單目運算符、算術運算符、關系運算符、邏輯運算符〔除邏輯非!〕、條件運算符、賦值運算符、逗號運算符。位運算符優(yōu)先級介于算術運算符與邏輯運算符之間。結合順序大多為自左向右,而自右向左的有三個:單目運算符、條件運算符和賦值運算符?!究键c3】printf函數(shù)格式為:printf(輸出控制,輸出列表)。輸出控制是用一對雙引號括起來的,包含格式說明和原樣信息。輸出列表包含假設干輸出項。【考點4】printf函數(shù)中格式說明%d對應整型,%f對應單精度實型,%c對應字符型,%o對應八進制無符號整型,%x對應無符號十六進制整型,%u對應無符號整型,%e對應指數(shù)型,%s對應字符串型??稍?和格式字符之間加一個數(shù)來控制數(shù)據(jù)所占的寬度和小數(shù)位數(shù)?!究键c5】scanf函數(shù)輸入項要求帶取地址符&。當用鍵盤輸入多個數(shù)據(jù)時,數(shù)據(jù)之間用分隔符。分隔符包括空格符、制表符和回車符,但不包括逗號。【考點】6如何交換兩個變量要使用中間變量,語句為:t=x;x=y;x=t;。第三章選擇結構【考點1】關系運算C語言用非0表示邏輯真,用0表示邏輯假。關系運算符有6個,分別是>,>=,<,<=,==,!=,前四種優(yōu)先級高于后兩種。關系表達式真時為1,假時為0。注意a<b<c是不可以的,可用(a<b)&&(b<c)來表示?!究键c2】邏輯運算邏輯運算符共有3個:邏輯與〔&&〕,邏輯或〔||〕,邏輯非〔!〕。注意短路現(xiàn)象,例a++||b++,如果表達式a++的值非零,那么表達式b++不再執(zhí)行?!究键c3】if語句可以單獨出現(xiàn),也可以與else匹配出現(xiàn)。if語句可以嵌套,這時else總是與離它最近的且沒有與else匹配的if匹配?!究键c4】條件運算是唯一的三目運算符,格式為:表達式1?表達式2:表達式3。表達式1值為非0時,整個表達式值為表達式2的值,表達式1值為0時,整個表達式值為表達式3的值??谠E:真前假后【考點5】switch語句格式及執(zhí)行過程詳見教材P33,要注意每條case后有沒有break語句的區(qū)別。還要注意switch后小括號里面的表達式不能為實型,case后表達式不能有變量。口訣:switch表不為實,case表不為變。第四章循環(huán)結構【考點1】三種循環(huán)結構三種循環(huán)結構分別為:while,do-while,for,三種結構的格式及執(zhí)行順序詳見教材第36、39、40頁。注意for循環(huán)中的小括號中必須是兩個分號;循環(huán)一定要有結束條件,否那么成了死循環(huán);do-while()循環(huán)最后的while();后一定要有分號。【考點2】break與continuebreak是終止所在整個循環(huán),而continue是提前結束本輪循環(huán)。break語句可出現(xiàn)在循環(huán)結構與switch語句中,continue只出現(xiàn)在循環(huán)結構中。【考點3】循環(huán)的嵌套就是循環(huán)里面還有循環(huán),計算要一層一層分析,一般只考查兩層嵌套,循環(huán)嵌套通常是處理二維數(shù)組?!究键c4】循環(huán)結構的復習循環(huán)結構是重點,筆試所占分值一般在13分左右,在上機考試中也是必考點,應用性很強。要求學員重點理解并多加練習,領會掌握。第五章字符型數(shù)據(jù)位運算【考點1】字符常量一個字符常量用一對單引號括起來,字符常量只能包括一個字符,’ab’是非法的??崭癯S谩酢瘉肀硎尽W址A靠捎脤腁SCII碼表示,需記住:’0’的ASCII碼為48,’A’的ASCII碼為65,’a’的ASCII碼為97。【考點2】轉義字符一對單引號中以一個反斜線后跟一個特定字符或八進制、十六進制數(shù)來構成轉義字符。比方’\n’表示換行,’\101’或’\x41’表示ASCII碼為65的字符’A’?!究键c3】字符型數(shù)據(jù)可以和整型數(shù)據(jù)相互轉換如:’0’-0=48‘A’+32=’a’chara=65;printf(“%d%c〞,a,a);結果為65A【考點4】位運算符C語言提供6種位運算符:按位求反~,按位左移<<,按位右移>>,按位與&,按位異或|,按位或^。一般情況下需要先轉化進制。異或運算的規(guī)那么:0異或1得到1,0異或0得到0,1異或1得到0。可記為“相同為0,不同為1”【考點5】putchar與getchar函數(shù)可用于輸出或輸入單個字符,這兩個函數(shù)是文件中的庫函數(shù),它們是printf與scanf函數(shù)的簡化。第六章函數(shù)【考點1】函數(shù)的定義函數(shù)是具有一定功能的一個程序塊。函數(shù)的首部為:函數(shù)類型函數(shù)名〔類型1形參1,類型2形參2,……〕。在函數(shù)定義中不可以再定義函數(shù),即不能嵌套定義函數(shù)。函數(shù)類型默認為int型?!究键c2】庫函數(shù)調(diào)用C語言標準庫函數(shù)時要包含include命令,include命令行以#開頭,后面是〞〞或<>括起來的后綴為〞.h〞的頭文件。以#開頭的一行稱為編譯預處理命令行,編譯預處理不是C語言語句,不加分號,不占運行時間。【考點3】函數(shù)的返回值函數(shù)通過return語句返回一個值,返回的值類型與函數(shù)類型一樣。return語句只執(zhí)行一次,執(zhí)行完或函數(shù)體結束后退出函數(shù)?!究键c4】函數(shù)的聲明函數(shù)要“先定義后調(diào)用〞,或“先聲明再調(diào)用后定義〞。函數(shù)的聲明一定要有函數(shù)名、函數(shù)返回值類型、函數(shù)參數(shù)類型,但不一定要有形參的名稱。【考點5】函數(shù)的調(diào)用程序從上往下執(zhí)行,當碰到函數(shù)名后,把值傳給調(diào)用函數(shù),當程序得到了返回值或調(diào)用函數(shù)結束,再順序往下執(zhí)行?!究键c6】函數(shù)的參數(shù)及值傳遞形式參數(shù)簡稱形參,是定義函數(shù)時函數(shù)名后面括號中的參數(shù)。實在參數(shù)簡稱實參,是調(diào)用函數(shù)時函數(shù)名后面括號中的參數(shù)。實參和形參分別占據(jù)不同的存儲單元。實參向形參單向傳遞數(shù)值。“傳值〞與“傳址〞的區(qū)別:傳數(shù)值的話,形參的變化不會改變實參的變化。傳地址的話,形參的變化就有可能改變實參所對應的量。【考點7】函數(shù)的遞歸調(diào)用函數(shù)直接或間接地調(diào)用自己稱為函數(shù)的遞歸調(diào)用。遞歸調(diào)用必須有一個明確的結束遞歸的條件。在做遞歸題時可把遞歸的步驟一步步寫下來,不要弄顛倒了?!究键c8】要求掌握的庫函數(shù)sqrt()算術平方根函數(shù),fabs()絕對值函數(shù),pow()冪函數(shù),sin()正弦函數(shù)第七章指針【考點1】指針變量指針變量是用來存儲地址的,而一般變量是存儲數(shù)值的。指針變量可指向任意一種數(shù)據(jù)類型,但不管它指向的數(shù)據(jù)占用多少字節(jié),一個指針變量占用四個字節(jié)?!究键c2】指針變量的定義格式為:類型名*指針變量名。二維指針int**p;可以理解為基類型為(int*)類型?!究键c3】指針變量的初始化指針變量在使用前必須要初始化,把一個具體的地址賦給它,否那么引用時會有副作用,如果不指向任何數(shù)據(jù)就賦“空值〞NULL?!究键c4】指針變量的引用&是取地址符,*是間接訪問運算符,它們是互逆的兩個運算符。在指針變量名前加間接訪問運算符就等價它所指向的量?!究键c5】指針的運算*p++和(*p)++之間的差異:*p++是地址變化,(*p)++是指針變量所指的數(shù)據(jù)變化。一個指針變量加一個整數(shù)不是簡單的數(shù)學相加,而是連續(xù)移動假設干地址。當兩個指針指向同一數(shù)組時,它們可以比擬大小進行減法運算。第八章數(shù)組【考點1】數(shù)組的定義數(shù)組是一組具有相同類型的數(shù)據(jù)的集合,這些數(shù)據(jù)稱為數(shù)組元素。格式為:類型名數(shù)組名[常量表達式]。數(shù)組的所占字節(jié)數(shù)為元素個數(shù)與基類型所占字節(jié)數(shù)的乘積。【考點2】數(shù)組的初始化第一維長度可以不寫,其它維必須寫。inta[]={1,2};合法,inta[][3]={2,3,4};合法,inta[2][]={2,3,4};非法。數(shù)組初始化元素值默認為0,沒有初始化元素值為隨機。如在inta[5]={0,1,2};中,元素a[4]值為0;而在inta[5];中,元素a[4]值為一個不確定的隨機數(shù)?!究键c3】元素的引用數(shù)組元素的下標從0開始,到數(shù)組長度減1

溫馨提示

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

評論

0/150

提交評論