![C語言程序的設計練習試題_第1頁](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/80f05507-cad1-4ceb-a123-bf0538a6c5a3/80f05507-cad1-4ceb-a123-bf0538a6c5a31.gif)
![C語言程序的設計練習試題_第2頁](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/80f05507-cad1-4ceb-a123-bf0538a6c5a3/80f05507-cad1-4ceb-a123-bf0538a6c5a32.gif)
![C語言程序的設計練習試題_第3頁](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/80f05507-cad1-4ceb-a123-bf0538a6c5a3/80f05507-cad1-4ceb-a123-bf0538a6c5a33.gif)
版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、C語言練習題(所提供的源程序均采用自定義函數(shù)方式解決,如不采用函數(shù)方式,也可直接在 main函數(shù)中借鑒該思想編程,因時間有限,所有程序未能一一驗證,僅供參 考使用)1、定義一個函數(shù)int fun(int a,int b,int c),它的功能是:若 a,b,c能構成等邊三角形函數(shù)返回3,若能構成等腰三角形函數(shù)返回2,若能構成一般三角形函數(shù)返回1,若不能構成三角形函數(shù)返回0。#i nclude <stdio.h>int fun (i nt a,i nt b,i nt c)if(a+b>c && b+c>a && a+c>b)if(a=
2、b && b=c )return 3;else if(a=b|b=c|a=c)return 2;else return 1;else return 0;void mai n()int a,b,c,shape;prin tf("n In put a,b,c:");sca nf("%d%d%d",&a,&b,&c);prin tf("na=%d, b=%d, c=%dn",a,b,c);shape =fun( a,b,c);prin tf("nn The shape : %dn "
3、;,shape);2、編寫一個程序,將兩個變量的值交換,例如變量a中的值原為3 , b中的值原 為8,程序運行后a中的值為8,b中的值為3。#include <stdio.h> void fun(int *x,int *y) int t;t=*x;*x=*y;*y=tvoid main()int a=3,b=8;printf("%d %dn",a,b);fun(&a,b);printf("%d %dn",a,b); 3、從鍵盤輸入3個數(shù),將最大值放在變量a中,最小值放在變量c中例如,輸入的數(shù)為: 55 12 34,輸出結(jié)果應當是: a
4、=55.0,b=34.0,c=12.0 #include <stdio.h> void fun(float *p,float *q,float *s)float k;if (*p<*q) k=*p;*p=*q;*q=k;if (*q<*s) k=*s;*s=*p;*p=k;if (*p<*q) k=*p;*p=*q;*q=k;void main() float a,b,c;printf("Input a b c: "); scanf("%f%f%f",&a,&b,&c); printf("a
5、=%4.1f,b=%4.1f,c=%4.1fnn",a,b,c); fun(&a,&b,&c);printf("a=%4.1f,b=%4.1f,c=%4.1fnn",a,b,c);4、編寫函數(shù)fun(int n),它的功能是:計算正整數(shù)n的所有因子(1和n除外)之 和作為函數(shù)值返回。例如:n=120寸,函數(shù)值為239。#include <stdio.h>#include <stdlib.h>int fun(int n)int i,s=0;for (i=2;i<n;i+)if (n%i=0) s=s+i;retu
6、rn s;void main() /* 主函數(shù)*/void NONO();printf("%dn",fun(120);NONO();void NONO( )/* 請在此函數(shù)內(nèi)打開文件,輸入測試數(shù)據(jù),調(diào)用 fun 函數(shù), 輸出數(shù)據(jù),關閉文件。 */FILE *wf;wf = fopen("a30.out", "w") ;fprintf(wf,"%dn",fun(120);fclose(wf) ;5、計算 s, 并輸出11 1S = 1 + + + +1+21+2+31+2+3+n1.833333n 通過鍵盤輸入,例如
7、:若 n 的值為 11 時,則函數(shù)值為: #include <stdio.h>#include <stdlib.h> float fun(int n) int i;float s=1.0,h=1;for (i=2;i<=n;i+) h=h+i; s=s+1.0/h; return s;void main()int n;float s; printf("nPlease enter N:");scanf("%d",&n); s=fun(n);printf("the result is:%f",s);
8、。高位7531。6、將一個整數(shù)中的每一位上為奇數(shù)的數(shù)依次取出, 構成一個新數(shù)放在 t 中 仍在高位,低位仍在低位。例如,當s中的數(shù)為:87653142寸,t中的數(shù)為: #include <stdio.h> void fun(long s,long *t)int d;long s1=1;*t=0;while (s>0)d=s%10;if(d%2!=0) *t=d*s1+*t; s1=s1*10;s/=10;main()long s,t; printf("nPlease enter s:");scanf("%ld",&s);fun(
9、s,&t);printf("The result is:%ldn",t);k的值從鍵盤傳7、計算并輸出k以內(nèi)最大的10個能被13或17整除的自然數(shù)之和 入,若k的值為500,則輸出4622。#include <stdio.h>int fun(int k)int m=0,mc=0,j;while(k>=1)&&(mc<10)if (k%13 = 0)|(k%17 = 0)m=m+k;mc+;k-;return m;void main()printf("%dn",fun(500);8、已知一個數(shù)列的前三項分別為
10、 0,0,1, 以后的各項都是其相鄰的前三項之 和,計算并輸出該數(shù)列前n項的平方根之和sum例如,當n= 10時,程序的輸出結(jié) 果應為: 23. 1 97745。#include <stdio.h>#include <math.h>double fun(n)double sum,s0,s1,s2,s;int k;sum = 1.0;if(n <= 2) sum = 0.0;s0 = 0.0; s1 = 0.0; s2 = 1.0;for (k = 4; k <= n; k+) s = s0 + s1 + s2;sum += sqrt(s);s0 = s1;
11、s1 = s2; s2 = s;return sum;void main ( )int n;printf("Input N=");scanf("%d", &n);printf("%fn", fun(n) );9、編寫一個程序,從鍵盤輸入 m輸出大于m且緊隨m勺素數(shù) #include <stdio.h> int fun(int m)int i,k;for (i=m+1;i+) for (k=2;k<i;k+) if(i%k=0) break;if (k>=i) return(i);void main()i
12、nt n;printf("nPlease enter n:");scanf("%d",&n); printf("%dn",fun(n);m 1, n 1)。方法 nW n,若m和n能同時它們有公因子 17)。10、判斷兩個整數(shù)nW n是否互質(zhì)(即是否有公共的因子)( 是:用2到t (t取nWn中較小的那個數(shù))之間的數(shù)分別去除 被某個數(shù)除盡,則nW n不互質(zhì);否則它們互質(zhì)。例如,若輸入187和85,則應輸出No(表示它們不互質(zhì), 若輸入89和187,則應輸出Yes (表示它們互質(zhì))。#include <stdio.h>
13、; int IsThat( int n, int n )int k, t, nk=1;t=n;if (n>n) t=n;for(k=2;k<=t;k+)if( n%k=0 && n%k=0 ) nk=0; break; return nk;void nain( )int n, n;printf( "nPlease enter 2 nunbers:n" ); scanf("%d %d", &n, &n);if( IsThat( n, n ) )printf( "Yesn" );elseprin
14、tf( "Non" );11、將十進制正整數(shù)m轉(zhuǎn)換成k進制數(shù)(2< k< 9)并輸出(m, k從鍵盤輸入) 例如,若輸入8和2,則應輸出 1000(即十進制數(shù) 8轉(zhuǎn)換成二進制表示是 1000) #include <stdio.h>void Trans( int m, int k )int aa20, i , j;for( i = 0; m; i+ )aai = m%k;m /= k;for( j=i-1; j>=0; j- ) printf("%d", aaj); void main()int b, n;printf( &q
15、uot;nPlease enter a number and a base:n" ); scanf("%d %d", &n, &b );Trans( n, b );12、統(tǒng)計從鍵盤輸入的 50 個實數(shù)中有多少個正數(shù)、多少個負數(shù)、多少個零 #include <stdio.h>void fun(int *zs,int *fs,int *l,float aa)int i; for(i=0;i<50;i+)if(aai>0) (*zs)+;if(aai<0) (*fs)+;if(aai=0)(*l)+;void main()f
16、loat num50;int i,czs,cfs,cl;czs=cfs=cl=0;printf( "nPlease enter 50 float numbers :n" ); for(i=0;i<50;i+)scanf( “%f” ,&numi); fun(&czs,&cfs,&cl,num);printf("n正數(shù):d ,負數(shù):d ,零:d n",czs,cfs,cl);13、計算并輸出方程 X2+Y2=1989 的所有整數(shù)解#include <stdio.h>void fun()int x,y;for
17、(x=1;x<=44;x+)for(y=1;y<=44;y+)if(x*x+y*y=1989)printf( “x=%d ,y=%d n ”,x,y);void main()printf( “方程 xA2+yA2=1989 的整數(shù)解為:n ”); fun();14、從鍵盤輸入 10 個整數(shù),求出其中的最大值。 #include <stdio.h> int fun(int aa)int m,i;m=aa0;for(i=1;i<10;i+)if(aai>m)m=aai;return m;void main()int num10,i;printf( “請從鍵盤輸入
18、 10個整數(shù) :n ”); for(i=0;i<10;i+)scanf( “%d” ,&numi);printf( “n 最大的數(shù)是 :%dn ”,fun(num); 123451123411123111121111115、從鍵盤輸入n值,輸出如右圖形。(例如n=5時)#i nclude <stdio.h>void fun (i nt n)int i,j;for(i=1;i<=n ;i+)for(j=1;j<=i;j+) printf(“%3d ,1);for(j=2;j<=n+1-i;j+) printf(“ %3d ,j);printf( “n
19、” ); void mai n()int n;printf(“n請輸入圖形的行數(shù):”);scanf( “%d,&n);fun(n);16、使用函數(shù)的方式,計算如下公式的值。1 1 1A1=1, A2 ,A3 ,An1+A11+A21+A(n-1)例如:若n=10,則應輸出:0.617977#include <stdio.h>float fun ( int n )float A=1; int i;for (i=1; i<=n; i+)A = 1.0/(1+A);return A ;void main( )int n ;printf("nPlease enter
20、 n: ") ;scanf("%d", &n ) ; printf("A%d=%fn", n, fun(n) ) ;廠 2,m = 1;13,m = 2;FFF( m ) =T 5,m = 3;L FFF(m - 3) + FFF(m - 1), m >例如,若輸入整數(shù) 9 ,則應輸出: 47 (不用做)18 、使用函數(shù)的方式,按以下遞歸公式求函數(shù)值r 10 (n=1)fun(n)= |fun (n-1)+2 (n >1)例如,當給n輸入5時,函數(shù)值為18;當給n輸入3時,函數(shù)值為14(不用做)19、計算并輸出當0vxv0.
21、97時下列多項式的值,直到|S(n)-S(n-1)|<0.000001 為止。0.5(0.5-10.5(0.5-E CO 5-2)0.5 CQ 5-1) CO. 5-2)-*(0 5-n+l)S=l+0. 5x+x*2+x*3 +jc«n2!3!n!例如,在主函數(shù)中從鍵盤給 x輸入0.21后,輸出為:s=1.100000。#i nclude <stdio.h>#in elude <math.h>double fun( double x)int n=1;/*循環(huán)計數(shù)*/double sn=1;/* 累計數(shù) */double xn=1,xn仁0; /*x的
22、n 值,以及 x 的 n-1 值;*/while(fabs(xn-xn 1)>=0.000001)/*絕對值是否合格 */xn=xn*x*(0.5-n+1)/n; /*表達式分解以后 xn=(xn-1)*x*(0.5-n+1)/n*/n+=1;sn+=xn;/*sn 累加上 xn*/return sn;void mai n()double x,s;prin tf("I nput x: "); sea nf("%lf", &x);s=fun( x);prin tf("s=%fn",s);20、計算并輸出 s。xA2 xA3
23、xA ns = 1 + x + + +1.349859 。2!3! n!n,x 從鍵盤輸入,例如,當 n=10,x=0.3 時,函數(shù)值為 #include <stdio.h> double fun(double x,int n)int i;double f=1.0,h=x; double s=1;s=s+h/f;for (i=2;i<=n;i+)f=f*i;h=h*x;s=s+h/f;return s;void main()printf("%fn",fun(0.3,10);21、從鍵盤輸入 high ,計算并輸出 high 以內(nèi)最大的 10個素數(shù)之和。例如
24、,輸入 high 的值為100,則輸出 732。#include <stdio.h>int fun( int high )int sum = 0, n=0, j, yes;while (high >= 2) && (n < 10)yes = 1;for (j=2; j<=high/2; j+ )if (high % j =0 )yes=0; break;if (yes=1)sum +=high; n+;high-;return sum ;void main ( )printf("%dn", fun (100);22、請編寫函數(shù)f
25、loat fun(int n),它的功能是:返回n (包括n)以內(nèi)能被5或9 整除的所有自然數(shù)的倒數(shù)之和。例如,n=20,返回0.583333。注意:要求n的值 不大于 100。#include <stdio.h>double fun(int n)int i;double sum=0.0; if(n>0&&n<=100)for (i=1;i<=n;i+) if(i%5=0|i%9=0)sum+=1.0/i;return sum;void main()int n; double s; printf("nInput n: ");sc
26、anf("%d",&n);s=fun(n);printf("nns=%fn",s);23、請編一個函數(shù) fun(int *a, int n, int *odd, int *even) ,函數(shù)的功能是 分別求出數(shù)組中所有奇數(shù)之和以及所有偶數(shù)之和。形參n給出數(shù)組a中數(shù)據(jù)的個數(shù);利用指針odd返回奇數(shù)之和,利用指針even返回偶數(shù)之和。例如:數(shù)組中的值依次為:1,9,2,3,11, 6;則利用指針odd返回奇數(shù) 之和 24;利用指針 even 返回偶數(shù)之和 8。#include <stdio.h>#define N 20fun ( int
27、*a, int n, int *odd, int *even )int i,sum_odd=0,sum_even=0;for(i=0;i<n;i+)if(ai%2=0)sum_even+=ai;elsesum_odd+=ai;*odd=sum_odd;*even=sum_even;void main( )int aN=1,9,2,3,11,6, i, n=6, odd, even;printf ( "The original data is : n" );for ( i = 0; i < n; i + ) printf ( "%5d", *(
28、a+i) );printf("nn");fun ( a, n, &odd, &even );printf ( "The sum of odd numbers: %dn", odd );printf ( "The sum of even numbers: %dn", even );24、編寫計算三角形面積的程序, 注意:將計算面積定義成函數(shù) float fun(int a,int b,int c)(a,b,c 為三角形的三條邊,返回三角形的面積 ) ,在主函數(shù)中調(diào) 用 fun#include <stdio.h>
29、;#include <math.h>float fun(int a,int b,int c)float p; p=(a+b+c)/2;return sqrt(p*(p-a)*(p-b)*(p-c);void main()int a,b,c;printf( “請輸入三角形三條邊 :n ” );scanf( “ %d%d%”d,&a,&b,&d);if(a+b>c && b+c>a && a+c>b)printf( “三角形面積為 :%.2f ”,fun(a,b,c);elseprintf( “無法構成三角形”
30、);25、編寫程序,求E=1+1/1! +1/2 ! +1/n!,要求最后一項的值小于10-4#include <stdio.h> double fun(int n)double m=1.0;int i=1;double p=1.0;dom=m+1.0/p;i+;p=p*i; while(1.0/p>=1E-4);return m;void main()int n; double s;printf("Input n: "); scanf("%d",&n);s=fun(n); printf("s=%fn",s)
31、;26、計算并輸出給定數(shù)組 (長度為 9)中每相鄰兩個元素之平均值的平方根之和。 例如,給定數(shù)組中的 9個元素依次為 12.0 、34.0 、4.0 、23.0 、34.0 、45.0 、18.0 、 3.0 、 11.0 ,輸出應為: s=35.951014。#include <stdio.h>#include <math.h>double fun(double x9)int i ;double avg=0.0,sum=0.0;for (i=0;i<8;i+)avg=(xi+xi+1)/2;sum+=sqrt(avg);return sum;void main(
32、)double s,a9=12.0,34.0,4.0,23.0,34.0,45.0,18.0,3.0,11.0;int i;printf("nThe original data is :n");for(i=0;i<9;i+)printf("%6.1f",ai); printf("nn");s=fun(a);printf("s=%fnn",s);27、將1到m之內(nèi)(含m)能被7或11整除的所有整數(shù)放在數(shù)組a中 例如,若輸入m的值為50,則在數(shù)組a中的值為:7 11 14 21 22 28 33 35 42 44
33、 49#include <stdio.h>#define M 100void fun ( int m, int *a , int *n )int i,count=0;for(i=1;i<=m;i+)if(i%7=0 | i%11=0) acount+=i;*n=count;void main( )int aaM, n, k;fun ( 50, aa, &n );for ( k = 0; k < n; k+ )if(k+1)%20=0) printf("n");else printf( "%4d", aak );printf
34、("n") ;28、請編寫函數(shù) int fun(int m,int score,int below),它的功能是:將低于平均分的人數(shù)作為函數(shù)值返回,并將低于平均分的成績放在below數(shù)組中(m表示score的長度,score表示成績)。例如,當score數(shù)組中的數(shù)據(jù)為:10、20、 30、40、50、60、70、80、90時,函數(shù)返回 4, below 中的數(shù)據(jù)應為:10、20、30、 40。#include <stdio.h>#include <stdlib.h>int fun(int score, int m, int below)int tot
35、al=0;int average=0;int *p_below=below;int i=0;int j=0;for(i=0;i<m;i+)total=total+scorei;average=total/m;for(i=0;i<m;i+)if(scorei<average)*p_below=scorei;p_below+;j+;*p_below=NULL;return(j);main( ) int i, n, below9 ;int score9 = 10, 20, 30, 40, 50, 60, 70, 80, 90 ;n = fun(score, 9, below) ;p
36、rintf( "nBelow the average score are: " ) ; for (i = 0 ; i < n ; i+) printf("%d ", belowi) ;29、用插入排序法將n個字符進行排序(降序)。(提示:插入法排序的思路是: 先對數(shù)組的頭兩個元素進行排序,然后根據(jù)前兩個元素的情況插入第三個元素, 再插入第四個元素)。#define N 80#include "stdio.h"#include "string.h"void insert(char *aa)int i,j,n;
37、char ch;n=strlen(aa);for(i=1;i<n;i+)ch=aai;j=i-1;while (j>=0)&&(ch<aaj)aaj+1=aaj;j-;aaj+1=ch;void main() char aN="QWERTYUIOPASDFGHJKLMNBVCXZ"int i;printf("The original string : %sn",a);insert(a);printf("The string after sorting:%snn",a);30、假定整數(shù)數(shù)組a中元素的值不
38、重復。刪除a中值為x的元素(x從鍵盤輸入) #include <stdio.h> #define N 20 fun(int *a,int n,int x) int p=0,i;an=x; while(x!=ap)p=p+1;if(p=n)return -1;else for(i=p;i<n;i+) ai=ai+1;return n-1;void main() int wN=-3,0,1,5,7,99,10,15,30,90,x,n,i;n=10; printf("The original data :n");for(i=0;i<n;i+) print
39、f("%5d",wi); printf("nInput x (to delete):");scanf("%d",&x); printf("Delete : %dn",x);n=fun(w,n,x);if (n=-1) printf("*Not be found!*nn");else printf("The data after deleted:n"); for(i=0;i<n;i+) printf("%5d",wi);printf("
40、;nn");原來排序的規(guī)律將它插入數(shù)組 a 中。 #include <stdio.h>#define M 20void InSort( int *n, int vv, int k ) int i=0 , j;while ( k > vvi && i < *n ) i+;if ( i<*n )for ( j=*n; j>i; j- ) vvj = vvj-1;vvi = k;+*n;void main()int aaM, i, k, m; system("cls");printf( "nPlease en
41、ter a number:n" ); scanf( "%d", &m );printf( "nPlease enter %d numbers:n", m ); for( i = 0; i < m; i+ )scanf( "%d", &aai );printf( "nPlease enter another number:n" ); scanf( "%d", &k );InSort( &m, aa, k );for(k=0; k < m;k+)
42、 printf( " %d", aak );32、使用數(shù)組的方法篩選出 1-100 中的素數(shù) #include <stdio.h> void fun ( int *pt )int i,j,flag;*pt=2;*pt+;for(i=3;i<100;i+)flag = 1;for(j=2;j<i;j+)if(i % j = 0)flag = 0;if( flag )*pt = i;*pt+;*pt=0;void main( )int *pointer,a30;pointer=a;fun(pointer);printf("The result
43、is :n");while(*pointer)printf ( "%d ",*pointer+ );33、已知一個數(shù)組 a 中包括 10 個整數(shù)元素,從 a 中第二個元素起,分別將后項 減前項之差存入數(shù)組b,并按每行3個元素輸出數(shù)組b#include <stdio.h>void fun(int a,int b)int i;for(i=1;i<10;i+)bi-1=ai-ai-1;for(i=0;i<9;i+)printf( “%3d”,bi);if(i+1)%3=0) printf(“n ” );void main()int a10=1,2
44、,3,4,5,6,7,8,9,10;int b9;fun(a,b);34、請編寫函數(shù)fun,函數(shù)的功能是:將M亍N列的二維數(shù)組中的字符數(shù)據(jù)按列的 順序依次放到一個字符串中。例如,二維數(shù)組中的數(shù)據(jù)為:W W W WS S S SH H H H則字符串中的內(nèi)容應是:WSHWSHWSH#include <stdio.h>void fun(int (*s)10, int *b, int *n, int mm, int nn)int x,y;for(x=0;x<nn;x+) for(y=0;y<mm;y+)bx*mm+y=*(sy+x);(*n)+;void main()int
45、w1010=33,33,33,33,44,44,44,44,55,55,55,55,i,j;int a100=0, n=0; printf("The matrix:n");for(i=0; i<3; i+) for(j=0;j<4; j+)printf("%3d",wij);printf("n"); fun(w,a,&n,3,4); printf("The A array:n");for(i=0;i<n;i+)printf("%3d",ai);printf("
46、nn");35、求出NX N勺二維數(shù)組周邊元素的平均值|0 1 2 7 9|1 9 7 4 5| a = |2 3 8 3 1|4 5 6 8 2|5 9 1 4 1| 則返回主程序后 s 的值應為: 3.375 。 #include <stdio.h> #define M 4 #define N 5 int fun ( int aMN )int i, j, sum = 0; for (i = 0; i < M; i+)for (j = 0; j < N; j+)if (i = 0)|(i = M - 1)|(j = 0)|(j = N - 1) ) sum
47、+= aij;return sum; void main( ) int aaMN=1,3,5,7,9,2,9,9,9,4, 6,9,9,9,8,1,3,5,7,0; int i, j, y;system("cls");printf ( "The original data is : n" ); for ( i=0; i<M; i+ ) for ( j =0; j<N; j+ ) printf( "%6d", aaij ); printf ("n"); y = fun ( aa ); printf( &q
48、uot;nThe sum: %dn" , y ); printf("n");36、求出 M 行 N 列的二維數(shù)組 tt 里每列中的最小元素,并依次放入 pp 數(shù)組 中。#include <stdio.h>#define M 3#define N 4void fun ( int ttMN, int ppN )int i, j, min;for(i = 0; i < N; i+)min = tt0i;for(j = 0; j < M; j+)if (min > ttji)min = ttji;ppi = min;void main( )
49、int t M N =22,45, 56,30,19,33, 45,38,20,22, 66,40;int p N , i, j, k;system("cls");printf ( "The original data is : n" );for( i=0; i<M; i+ )for( j=0; j<N; j+ )printf ( "%6d", tij );printf("n");fun ( t, p );printf( "nThe result is:n" );for ( k =
50、0; k < N; k+ ) printf ( " %4d ", p k );printf("n");37、請編寫程序,實現(xiàn)B=A+A',即把矩陣A加上A的轉(zhuǎn)置,存放在矩陣B中。計算 結(jié)果在main函數(shù)中輸出。例如,輸入下面的矩陣: 其轉(zhuǎn)置矩陣為:|1 23|147|4 56|258|7 89|369|程序輸出:|2 6 10|6 10 14|10 14 18|#include <stdio.h>void fun(int a33,int b33)int i,j;for(i=0;i<3;i+)for (j=0;j<3;
51、j+)bij=aij+aji;void main() int a33=1,2,3,4,5,6,7,8,9,t33;int i,j;fun(a,t);for(i=0;i<3;i+) for(j=0;j<3;j+)printf("%7d",tij);printf("n");38、編寫程序刪除字符串s中從下標k開始的n個字符(n和k從鍵盤輸入)。 例如,字符串內(nèi)容為:Hellollo World!,k中的值為:5,n中的值為:3,結(jié)果 為: Hello World! 。#include <stdio.h>#define N 80void
52、 fun(char *a,int k,int n)int i;i=k;while (ai-1!='0') ai=ai+n;i=i+1;void main() char sN="Hellollo World!"int k,n;printf("nThe original string:%sn",s);printf("Enter index k: "),scanf("%d",&k);printf("Enter number to delete n: ");scanf("
53、;%d",&n);fun(s,k,n);printf("nThe string after deleted: %sn",s);NONO();39、編寫程序, 從鍵盤輸入字符串 tt ,將其中每個單詞的首字符改為對應的大寫 字母,首字符后的字母都改為對應的小寫字母。例如,若輸入字符串: "ab cD bOYxy!" ,則輸出字符串為: "Ab Cd Boyxy!" #include <stdio.h> #include <string.h> char* EXUL( char tt )int is
54、first = 1;int i, length;length = strlen( tt );for(i = 0; i < length; i+) if (tti >= 'a' && tti <= 'z')tti = isfirst?(tti + 'A' - 'a'):tti;isfirst=0; else if (tti >= 'A' && tti <= 'Z')tti = isfirst?tti:(tti - 'A' +
55、 'a');isfirst=0; elseisfirst = 1;return tt;main()int i;char tt81;printf("nPlease enter a string: "); gets( tt );printf( "nThe result string is:%sn", EXUL( tt ) );40、編寫程序,從鍵盤輸入字符串tt ,字符串中'a'到'z'26個字母各自出現(xiàn)的次 數(shù),并依次放在pp所指數(shù)組中。例如,當輸入字符串: abcdefgabcdeabc 后,程序的輸出結(jié)果
56、應該是: 3 3 32 2 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0#include <stdio.h>void fun(char *tt, int pp)char *p_tt=tt;int i=0;while(i<26)ppi=0;i+;for(;*p_tt!=NULL;p_tt+)switch(*p_tt)case 'a':pp0+;break;case 'b':pp1+;break;case 'c':pp2+;break;case 'd':pp3+;break;ca
57、se 'e':pp4+;break;case 'f':pp5+;break;case 'g':pp6+;break;case 'h':pp7+;break;case 'i':pp8+;break;case 'j':pp9+;break;case 'k':pp10+;break;case 'l':pp11+;break;case 'm':pp12+;break;case 'n':pp13+;break;case 'o':p
58、p14+;break;case 'p':pp15+;break;case 'q':pp16+;break;case 'r':pp17+;break;case 's':pp18+;break;case 't':pp19+;break;case 'u':pp20+;break;case 'v':pp21+;break;case 'w':pp22+;break;case 'x':pp23+;break;case 'y':pp24+;break
59、;case 'z':pp25+;break;main( ) char aa1000 ;int bb26, k, n ;printf( "nPlease enter a char string:" ) ; scanf("%s", aa) ;fun(aa, bb ) ;for ( k = 0 ; k < 26 ; k+ ) printf ("%d ", bbk) ;printf( "n" ) ;41、請編寫程序,把字符串s中所有的字符前移一個位置,串中的第一個字符移 到最后。例如:原有的字符串為:Mn .123xyZ,貝U調(diào)用該函數(shù)后,串中的內(nèi)容為:n.123xyZM。#include &l
溫馨提示
- 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年中外合資協(xié)議
- 2025年雙開門設計與供應安裝協(xié)議書
- 2025年云南貨運從業(yè)資格證考試科目一模擬考試
- 2025年四川貨運資格證試題答案解析
- 2025年貴州貨運資格考試答案
- 2025年農(nóng)村個人宅基地使用權贈與合同范文
- 2025年工程策劃外包合同模板
- 2025年合作伙伴綜合性策劃協(xié)議
- 2025年停車場規(guī)劃與管理合同
- 2025年個人房產(chǎn)交換協(xié)議文本
- 電流互感器試驗報告
- 蔣中一動態(tài)最優(yōu)化基礎
- 華中農(nóng)業(yè)大學全日制專業(yè)學位研究生實踐單位意見反饋表
- 付款申請英文模板
- 七年級英語閱讀理解10篇(附答案解析)
- 抖音來客本地生活服務酒旅商家代運營策劃方案
- 鉆芯法樁基檢測報告
- 無線網(wǎng)網(wǎng)絡安全應急預案
- 國籍狀況聲明書【模板】
- 常用保潔綠化人員勞動合同范本5篇
- 新高考高一英語時文閱讀
評論
0/150
提交評論