- 1./*教材p.97*/
- #include<stdio.h>
- main()
- {
- int*p,m,n;
- scanf("%d%d",&m,&n);
- if(m>n)
- p=&n;
- else
- p=&m;
- printf("%d/n",*p);
- }
- /*用指针指向两个变量,通过指针运算选出最小数*/
- **************************************************************************
- 2./*教材p.100*/
- #include<stdio.h>
- voidorder(int*a,int*b);
- main()
- {
- intm,n;
- order(&m,&n);
- printf("%d/n%d/n",m,n);
- }
- voidorder(int*a,int*b)
- {
- intx,y;
- scanf("%d%d",&x,&y);
- if(x<y)
- {
- *a=x;
- *b=y;
- }
- else
- {
- *a=y;
- *b=x;
- }
- }
- /*使调用函数中的第一个实参总是存放两个数中的较小的数,第二个存放较大的*/
- **************************************************************************
- 3./*教材p.101*/
- #include<stdio.h>
- int*max(int*);
- main()
- {
- intx,y;
- y=max(&x);
- printf("%d/n",y);
- }
- int*max(int*a)
- {
- intm,n;
- scanf("%d%d",&m,&n);
- if(m>n)
- *a=m;
- else
- *a=n;
- return*a;
- }
- /*输入两个数输出最大数*/
- **************************************************************************
- 4./*教材p.108*/
- #include<stdio.h>
- main()
- {
- inti,j,n=-1,x=0,y=0,a[30];
- for(i=0;i<=29;i++)
- {
- n+=2;
- a[i]=n;
- x++;
- if(x%10!=0)
- printf("%4d",a[i]);
- else
- {
- printf("%4d",a[i]);
- printf("/n");
- }
- }
- printf("/n");
- for(j=29;j>=-1;j--)
- {
- y++;
- if(y%10!=0)
- printf("%4d",a[j]);
- else
- {
- printf("%4d",a[j]);
- printf("/n");
- }
- }
- }
- /*给数组赋奇数,先每行10个正序输出,再每行10个逆序输出*/
- **************************************************************************
- 5./*教材p.112*/
- #include<stdio.h>
- int*sr(int*p)
- {
- inti=0;
- do
- {
- scanf("%d",p);
- i++;
- }
- while(*p>=0);
- returni;
- }
- main()
- {
- intn,a[100],j=0;
- j=sr(a);
- for(n=0;n<j;n++)
- printf("%4d",a[n]);
- }
- /*输入大于等于0的数,负数结束,并输出它们。*/
- **************************************************************************
- 6./*教材p.113*/
- #include<stdio.h>
- voidgb(char*p);
- main()
- {
- inti;
- chars[10];
- for(i=0;i<10;i++)
- s[i]=getchar();
- gb(s);
- }
- voidgb(char*p)
- {
- inti;
- for(i=4;i<10;i++)
- *(p+i)='*';
- for(i=0;i<10;i++)
- printf("%c",p[i]);
- printf("/n");
- }
- /*对有10个元素的字符型数组,从下标4开始,全部变为"*",其他不变.*/
- **************************************************************************
- 7./*教材p.117*/
- #include<stdio.h>
- #defineM8
- voiddx(int*);
- main()
- {
- inta[M]={10,20,30,40,50,60,70,80};
- dx(a);
- }
- voiddx(int*a)
- {
- inti,j,t,n;
- for(i=0;i<M-1;i++)/*处理好i和j初值与上界能使算法复杂度变小*/
- for(j=i+1;j<M;j++)
- if(a[i]<a[j])
- {
- t=a[i];
- a[i]=a[j];
- a[j]=t;
- }
- for(n=0;n<M;n++)
- printf("%d/n",a[n]);
- }
- /*逆序输出数组a*/
- /*此题应用冒泡排序,不能用首尾比较交换*/
- **************************************************************************
- 8./*教材p.118*/
- #include<stdio.h>
- #include<stdlib.h>
- #defineN50
- #defineM10
- voidtjgs(int*);
- main()
- {
- intstr[N],i;
- for(i=0;i<N;i++)
- str[i]=rand()%10;
- tjgs(str);
- }
- voidtjgs(int*str)
- {
- inti,k,j=0;
- for(k=0;k<M;k++)
- {
- for(i=0;i<N;i++)
- if(str[i]==k)
- j++;
- printf("%d:%d/n",k,j);
- j=0;/*j为记数的东西,所以当次记完后应重新赋值0,以便下次记数*/
- }
- }
- /*整形数组中的值在0至9范围内,统计每个整数个数*/
- **************************************************************************
- 9./*教材p.121*/
- #include<stdio.h>
- #defineN6
- int*px(int*);
- voidsc(int*,int);
- main()
- {
- intm=0,a[N]={5,7,4,2,8,6};
- m=px(a);
- sc(m,N);
- }
- int*px(int*a)
- {
- inti,k,t;
- for(k=0;k<N-1;k++)/*此处应正确给出k,i的初值及上界,才能使算法复杂度最小*/
- for(i=k+1;i<N;i++)
- if(a[k]>a[i])
- {
- t=a[k];
- a[k]=a[i];
- a[i]=t;
- }
- returna;
- }
- voidsc(inta[],intn)
- {
- inti;
- for(i=0;i<n;i++)
- printf("%4d",a[i]);
- printf("/n");
- }
- /*把数组中数由小到大排列*/
- **************************************************************************
- 10./*教材p.126*/
- #include<stdio.h>
- main()
- {
- inta[2][3],i,j;
- for(i=0;i<2;i++)
- for(j=0;j<3;j++)
- scanf("%d",&a[i][j]);
- for(i=0;i<2;i++)
- {
- for(j=0;j<3;j++)
- printf("%4d",a[i][j]);
- printf("/n");
- }
- }
- /*输出:123102030<CR>时
- 输出是否为:123
- 102030*/
- **************************************************************************
- 11./*教材p.132*/
- #include<stdio.h>
- #defineM7
- #defineN7
- main()
- {
- intm,n,a[M][N];
- for(m=0;m<M;m++)
- a[m][0]=1;
- for(n=0;n<N;n++)
- a[n][n]=1;
- for(m=2;m<M;m++)
- for(n=1;n<m;n++)
- a[m][n]=a[m-1][n-1]+a[m-1][n];
- for(m=0;m<M;m++)
- {
- for(n=0;n<=m;n++)
- printf("%4d",a[m][n]);
- printf("/n");
- }
- }
- /*打印出杨辉三角:
- 1
- 11
- 121
- 1331
- 14641
- 15101051
- 1615201561*/
- **************************************************************************
- 12./*教材p.133*/
- #include<stdio.h>
- #include<stdlib.h>
- #defineM10
- #defineN10
- main()
- {
- intm,n,t,k,a[M][N];
- for(m=0;m<M;m++)
- {
- for(n=0;n<N;n++)
- {
- a[m][n]=rand()%50;
- printf("%4d",a[m][n]);
- }
- printf("/n");
- }
- for(n=0;n<N;n++)
- {
- t=a[0][n];
- for(m=0;m<M;m++)
- if(a[m][n]<t)
- {
- t=a[m][n];
- k=m;
- }
- printf("min(%d):%d/n",t,k);
- }
- }
- /*找出方阵每列中最小元素,及所在行号*/
- **************************************************************************
- 13./*教材p.87*/
- #include<stdio.h>
- #include<ctype.h>
- inttj(int);
- main()
- {
- intx=0,y=0;
- y=tj(x);
- printf("y=%d/n",y);
- }
- inttj(inti)
- {
- charch;
- do
- {
- ch=getchar();
- switch(ch)
- {
- case'':i++;break;
- case'/n':i++;break;
- case'/t':i++;break;
- }
- }
- while(ch!='@');
- returni+1;
- }
- /*统计文章单词数,出现'@'时结束统计*/
- **************************************************************************
- 14./*教材p.149*/
- #include<stdio.h>
- #defineM1000
- intslength();
- main()
- {
- chara[M];
- intx=0;
- scanf("%s",a);
- x=slength(a);
- printf("%d/n",x);
- }
- intslength(char*s)
- {
- intm=0;
- while(1)/*使用while的永真循环,但return使循环结束.*/
- if(*(s+m)=='/0')
- returnm;
- elsem++;
- }
- /*利用编写的函数,使函数返回指针所指字符串长度*/
- /*注意:输入时别越界,越界系统并不包错,且照常统计,但如果再实现其他功能,则会影响结果。输入时空格是间隔符,使程序停止统计,且空格本身不被统计。*/
- **************************************************************************
- 15./*自己出的*/
- #include<stdio.h>
- main()
- {
- chara;
- while(a!='/n')
- {
- scanf("%c",&a);
- if(a>='A'&&a<='Z')
- printf("%c",a+32);
- else
- if(a>='a'&&a<='z')
- printf("%c",a-32);
- else
- if(a!='/n')/*如果此处不加这个条件,那么输出时总有"Error!"*/
- printf("Error!");
- else
- printf("/n");
- }
- }
- /*把文中的大小写字母相互转换,不是字母时输出错误提示*/
- **************************************************************************
- 16./*自己出的*/
- #include<stdio.h>
- #defineM100
- #defineN10
- main()
- {
- inti=0,k,m,t,x,y,a[M],b[N][N],c[N]={0},E=0,F=0,J=0;
- floatd[N]={0.0};
- for(k=1;k<1000;k++)
- {
- for(m=2;m<=k/2;m++)
- if(k%m==0)
- {
- t=0;
- break;
- }
- else
- t=1;
- if(t==0)
- ;
- else
- {
- if(i>=100)
- break;
- else
- a[i]=k;
- printf("a[%2d]=%3d/t",i++,k);
- }
- }
- printf("/n");
- for(i=0;i<M;i++)
- {
- printf("%d/t",a[i]);
- if((i+1)%10==0)
- printf("/n");
- }
- for(i=0;i<M;i++)
- {
- x=i/10;
- y=i%10;
- b[x][y]=a[i];
- }
- for(x=0;x<N;x++)
- {
- for(y=0;y<N;y++)
- c[x]+=b[x][y];
- d[x]=c[x]/N;
- printf("行和:c[%d]=%d/t行均数:d[%d]=%f/t",x,c[x],x,d[x]);
- }
- printf("/n");
- for(y=0;y<N;y++)
- {
- for(x=0;x<N;x++)
- c[y]+=b[x][y];
- d[y]=c[y]/N;
- printf("列和:c[%d]=%d/t列均数:d[%d]=%f/t",y,c[y],y,d[y]);
- }
- printf("/n");
- for(x=0;x<N;x++)
- E+=b[x][x];
- printf("左右对角线和:E=%d/n",E);
- for(x=0;x<N;x++)
- F+=b[x][(N-1)-x];
- printf("右左对角线和:F=%d/n/n",F);
- for(x=0;x<N;x++)
- for(y=0;y<N;y++)
- if(b[x][y]/100==3||(b[x][y]/10)%10==3||b[x][y]%10==3)
- J++;
- printf("含'3'的数字的个数:J=%d/n/n",J);
- }
- /*输出100个素数,然后按10*10矩阵输出,再输出行和、列和、行均数、列均数、对角线和;并统计含'3'的数字的个数*/
- /*素数定义:只能被一和本身整除的自然数*/
- **************************************************************************
- 17./*教材p.90题7.12*/
- #include<stdio.h>
- doublefun(double,int);
- main()
- {
- doublea,c;
- intb;
- scanf("%lf%d",&a,&b);
- c=fun(a,b);
- printf("(%f)%d=%f/n",a,b,c);
- }
- doublefun(doublex,inty)
- {
- inti;
- doublez=1.0;
- for(i=1;i<=y;i++)
- z*=x;
- returnz;
- }
- /*编一个函数求a的b次方*/
- **************************************************************************
- 18./*教材p.149*/
- #include<stdio.h>
- #defineM1000
- intslength(char*s);
- main()
- {
- intx;
- chara[M];
- scanf("%s",a);
- x=slength(a);
- printf("%d/n",x);
- }
- intslength(char*s)
- {
- intm=0;
- while(1)
- if(*(s+m)=='/0')
- returnm;
- else
- m++;
- }
- /*编写函数,使函数返回指针所指字符串长度。*/
- **************************************************************************
- 19./*教材p.149*/
- #include<stdio.h>
- #defineM1000
- voidscopy(char*s,char*t);
- main()
- {
- chara[M],b[M-1];
- scanf("%s",b);
- scopy(a,b);
- printf("%s/n",a);
- }
- voidscopy(char*s,char*t)
- {
- inti,n=0;
- while(t[n]!='/0')/*只要累计寻找或计数,那么就要用循环*/
- n++;
- for(i=0;i<n+1;i++)
- {
- s[i]=t[i];
- }
- }
- /*将指针t所指的字符串复制到指针s所指的存储空间中*/
- **************************************************************************
- 20./*教材p.150*/
- #include<stdio.h>
- #defineM1000
- intscomp(char*s1,char*s2);
- main()
- {
- chara[M],b[M];
- intx;
- scanf("%s%s",a,b);
- x=scomp(a,b);
- switch(x)
- {
- case1:printf("a>b/n");break;
- case0:printf("a=b/n");break;
- case-1:printf("a<b/n");break;
- }
- }
- intscomp(char*s1,char*s2)
- {
- inti,k,n=0,m=0;
- while(s1[n]!='/0')/*因为是计数所以用循环*/
- n++;
- while(s2[m]!='/0')
- m++;
- if(m>=n)
- k=m;
- else
- k=n;
- for(i=0;i<k;i++)
- {
- if(s1[i]>s2[i])
- return1;
- else
- if(s1[i]<s2[i])
- return-1;
- else
- continue;
- }
- return0;
- }
- /*编写函数,进行字符串比较。*/
- **************************************************************************
- 21./*教材p.150*/
- #include<stdio.h>
- #defineM40
- #defineN61
- main()
- {
- chara[M][N];
- inti,j,m=0,x=1;
- for(i=0;i<M;i++)
- {
- for(j=0;j<N-1;j++)/*此for循环内部不可以为每个字符串记字符的个数,因为每个字符串的个数都不一样.*/
- {
- scanf("%c",&a[i][j]);
- if(a[i][j]=='/n'||a[i][j]==''||a[i][j]=='/t')
- {
- a[i][j]='/n';/*把空格与制表符变成切断符*/
- break;
- }
- }
- if(a[i][0]=='/n')
- break;
- m++;
- }
- for(i=0;i<m;i++)
- {
- printf("%d:",x++);
- for(j=0;a[i][j]!='/n';j++)
- printf("%c",a[i][j]);
- printf("/n");
- }
- }
- /*从终端读入若干文本行(不超过40行,每行不超过60个字符),
- 遇空行结束输入,然后将此文本左侧加上行号后输出*/
- /*当连续出现换行符,空格,制表符时,则后面输入的不起作用*/
- **************************************************************************
- 22./*教材p.150*/
- #include<stdio.h>
- #defineM40
- #defineN61
- main()
- {
- chara[M][N];
- inti,j,m=0,n=0,x=1;
- for(i=0;i<M;i++)
- {
- for(j=0;j<N-1;j++)
- {
- //scanf("%c",&a[i][j]);
- a[i][j]=getchar();
- //n++;
- //这里n没有作用,字符串长度都不一样的
- //if(a[i][j]=='/n'||a[i][j]==''||a[i][j]=='/t')
- //字符串可以包含空字符,而且gets认为空格是字符,而%s认为空格是切断符。
- if(a[i][j]=='/n')
- break;
- }
- if(a[i][0]=='/n')
- break;
- m++;
- //必须换成串结束符,否则编译后结果错误
- a[i][j]='/0';
- }
- for(i=0;i<m;i++)/*应除去最后一行即(i<m-1),因为最后一行是空行*/
- {
- printf("%d:",x++);
- //for(j=0;j<n-1;j++)
- //printf("%c",a[i][j]);
- printf("%s/n",a[i]);
- }
- }
- /*从终端读入若干文本行(不超过40行,每行不超过60个字符),
- 遇空行结束输入,然后将此文本左侧加上行号后输出*/
- /*这是朋友在我的错误的基础上改的,且把空格与制表符当成字符*/
- **************************************************************************
- 23./*教材p.151*/
- #include<stdio.h>
- #include<string.h>
- #defineM100
- main()
- {
- chara[M][M],*t;
- inti,m=0;
- for(i=0;i<M;i++)
- {
- scanf("%s",a[i]);
- if(*a[i]=='@')
- break;
- m++;
- }
- t=a[0];
- for(i=1;i<m;i++)
- {
- if(strcmp(t,a[i])>=0)/*因为是终于最小的比较,所以是t而不是a[0]*/
- t=a[i];
- }
- printf("TheminStringis:%s/n",t);
- }
- /*从输入的若干字符串(不超过100个)中找出最小的串进行输出,当字符串为@时结束输入*/
- **************************************************************************
- 24./*教材p.151*/
- #include<stdio.h>
- #include<string.h>
- #defineM100
- main()
- {
- chara[M][M],*t;
- inti,j,m=0;
- for(i=0;i<M;i++)
- {
- for(j=0;j<M;j++)
- {
- a[i][j]=getchar();/*这样一来空格,制表符都是字符了,而不是间断符*/
- if(a[i][j]=='/n'||a[i][j]==''||a[i][j]=='/t')/*但这一句使空格,制表符又是间断符了*/
- break;
- }
- if(a[i][0]=='/n')
- break;
- m++;
- a[i][j]='/0';
- }
- t=a[0];
- for(i=1;i<m;i++)
- {
- if(strcmp(t,a[i])>=0)/*因为是终于最小的比较,所以是t而不是a[0]*/
- t=a[i];
- }
- printf("TheminStringis:%s/n",t);
- }
- /*从输入的若干字符串(不超过100个)中找出最小的串进行输出。*/
- /*受2009-06-20-004(2).c中的语句启发,自己在2009-07-07-001.c的基础上改编的。*/
- /*与2009-07-07-001.c除了程序语句有区别外,结束符也有区别:*/
- /*这个不用"@"字符串结束,而用回车结束*/
- **************************************************************************
- 25./*自己出的*/
- #include<stdio.h>
- main()
- {
- inti,j,k;
- for(k=0;k<4;k++)
- {
- for(i=0;i<k;i++)
- printf("");
- for(j=0;j<7-2*k;j++)/*注意2与k相乘时之间应加星号*/
- printf("*");
- printf("/n");
- }
- }
- /*打印倒三角*/
- **************************************************************************
- 26./*教材p.160*/
- #include<stdio.h>
- intfun(intm)
- {
- if(m==1)
- return1;
- else
- returnm*fun(m-1);
- }
- main()
- {
- intm,s;
- scanf("%d",&m);
- if(m<0)
- printf("Error!/n");
- else
- if(m==0)
- printf("(%d!)=1/n",m);
- else
- {
- s=fun(m);
- printf("(%d!)=%d/n",m,s);
- }
- }
- /*利用函数的递归调用,求一个数的阶乘*/
- **************************************************************************
- 27./*教材p.162*/
- #include<stdio.h>
- #include<math.h>
- doublefun(doublea,doublex0)
- {
- doublex1;
- x1=(x0+a/x0)/2.0;
- while(fabs(x1-x0)>1e-6)
- returnfun(a,x1);/*若此处不加return则下面returnx1返回的始终是x1的第一次的值。而不是最终求的x1的值。最终求的x1的值,确实求出来了在临时内存中,但没被返回。*/
- returnx1;
- }
- main()
- {
- doublea,x,x0=1.0;
- scanf("%lf",&a);
- if(a<0)
- printf("Error!/n");
- else
- x=fun(a,x0);
- printf("%lf/n",x);
- }
- /*根据此求平方根的迭代公式:x1=((x0+(a/x0))/2)求某数a的平方根*/
- **************************************************************************
- 28./*教材p.162*/
- #include<stdio.h>
- #include<math.h>
- doublefun(doublea,doublex0)
- {
- doublex1;
- x1=(x0+a/x0)/2.0;
- if(fabs(x1-x0)>1e-6)
- returnfun(a,x1);/*若此处不加return则下面returnx1返回的始终是x1的第一次的值。而不是最终求的x1的值。最终求的x1的值,确实求出来了在临时内存中,但没被返回。*/
- else
- returnx1;
- }
- main()
- {
- doublea,x,x0=1.0;
- scanf("%lf",&a);
- if(a<0)
- printf("Error!/n");
- else
- x=fun(a,x0);
- printf("%lf/n",x);
- }
- /*根据此求平方根的迭代公式:x1=((x0+(a/x0))/2)求某数a的平方根*/
- /*教材的原答案*/
- **************************************************************************
以上程序均为自己写的,属于原创!只是题目是书上的题。