admin 管理员组

文章数量: 887021


2023年12月24日发(作者:软件工程技术与软件工程的区别)

C 语言课后习题答案-第四版- 谭浩强(1-7)

第一章

#include

int main ( )

{ printf ("**************************nn");

printf(" Very Good!nn");

printf ("**************************n");

return 0;

}

#include

int main()

{int a,b,c,max;

printf("please input a,b,c:n");

scanf("%d,%d,%d",&a,&b,&c);

max=a;

if (max

max=b;

if (max

max=c;

printf("The largest number is %dn",max);

return 0;

}

第 3 章

#include

#include

int main()

{float p,r,n;

r=0.1;

n=10;

p=pow(1+r,n);

printf("p=%fn",p);

return 0;

}

#include

#include

int main()

{float r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;

p=1000;

r5=0.0585;

r3=0.054;

r2=0.0468;

r1=0.0414;

r0=0.0072;

p1=p*((1+r5)*5);

p2=p*(1+2*r2)*(1+3*r3);

p3=p*(1+3*r3)*(1+2*r2);

p4=p*pow(1+r1,5);

p5=p*pow(1+r0/4,4*5);

printf("p1=%fn",p1);

printf("p2=%fn",p2);

printf("p3=%fn",p3);

printf("p4=%fn",p4);

printf("p5=%fn",p5);

return 0;

}

#include

#include

// 一次存 5 年期

// 先存 2 年期,到期后将本息再存 3 年期

// 先存 3 年期,到期后将本息再存 2 年期

// 存 1 年期,到期后将本息存再存 1 年期,连续存 5 次// 存活期存款。活期利息每一季度结算一次

// 输出按第 1

方案得到的本息和

// 输出按第 2

方案得到的本息和

// 输出按第 3

方案得到的本息和

// 输出按第 4

方案得到的本息和

// 输出按第 5

方案得到的本息和

int main()

{double r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;

p=1000;

r5=0.0585;

r3=0.054;

r2=0.0468;

r1=0.0414;

r0=0.0072;

p1=p*((1+r5)*5);

p2=p*(1+2*r2)*(1+3*r3);

p3=p*(1+3*r3)*(1+2*r2);

p4=p*pow(1+r1,5);

p5=p*pow(1+r0/4,4*5);

printf("p1=%fn",p1);

printf("p2=%fn",p2);

printf("p3=%fn",p3);

printf("p4=%fn",p4);

printf("p5=%fn",p5);

return 0;

}

// 一次存 5 年期

// 先存 2 年期,到期后将本息再存 3 年期

// 先存 3 年期,到期后将本息再存 2 年期

// 存 1 年期,到期后将本息存再存 1 年期,连续存 5 次// 存活期存款。活期利息每一季度结算一次

// 输出按第 1

方案得到的本息和

// 输出按第 2

方案得到的本息和

// 输出按第 3

方案得到的本息和

// 输出按第 4

方案得到的本息和

// 输出按第 5

方案得到的本息和

#include

#include

int main()

{float r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;

p=1000;

r5=0.0585;

r3=0.054;

r2=0.0468;

r1=0.0414;

r0=0.0072;

p1=p*((1+r5)*5);

p2=p*(1+2*r2)*(1+3*r3);

p3=p*(1+3*r3)*(1+2*r2);

p4=p*pow(1+r1,5);

p5=p*pow(1+r0/4,4*5);

printf("p1=%10.2fn",p1);

printf("p2=%10.2fn",p2);

printf("p3=%10.2fn",p3);

printf("p4=%10.2fn",p4);

printf("p5=%10.2fn",p5);

return 0;

// 一次存 5 年期

// 先存 2 年期,到期后将本息再存 3 年期

// 先存 3 年期,到期后将本息再存 2 年期

// 存 1 年期,到期后将本息存再存 1 年期,连续存 5 次// 存活期存款。活期利息每一季度结算一次

// 输出按第 1 方案得到的本息和

// 输出按第 2 方案得到的本息和

// 输出按第 3 方案得到的本息和

// 输出按第 4 方案得到的本息和

// 输出按第 5 方案得到的本息和

}

#include

#include

int main()

{float d=300000,p=6000,r=0.01,m;

m=log10(p/(p-d*r))/log10(1+r);

printf("m=%6.2fn",m);

return 0;

}

#include

int main()

{int c1,c2;

c1=197;

c2=198;

printf("c1=%c,c2=%cn",c1,c2);

printf("c1=%d,c2=%dn",c1,c2);

return 0;

}

#include

int main()

{int a,b;

float x,y;

char c1,c2;

scanf("a=%d b=%d",&a,&b);

scanf("%f %e",&x,&y);

scanf("%c%c",&c1,&c2);

printf("a=%d,b=%d,x=%f,y=%f,c1=%c,c2=%cn",a,b,x,y,c1,c2);

return 0;

}

#include

int main()

{char c1='C',c2='h',c3='i',c4='n',c5='a';

c1=c1+4;

c2=c2+4;

c3=c3+4;

c4=c4+4;

c5=c5+4;

printf("passwor is %c%c%c%c%cn",c1,c2,c3,c4,c5);

return 0;

}

#include

int main ()

{float h,r,l,s,sq,vq,vz;

float pi=3.141526; printf("请输入圆半径 r,圆柱高 h∶");

scanf("%f,%f",&r,&h);

//要求输入圆半径 r 和圆柱高 h

//计算圆周长 l

//计算圆面积 s

//计算圆球表面积 sq

//计算圆球体积 vq

//计算圆柱体积 vz

l=%6.2fn",l);

s=%6.2fn",s);

sq=%6.2fn",sq);

l=2*pi*r;

s=r*r*pi;

sq=4*pi*r*r;

vq=3.0/4.0*pi*r*r*r;

vz=pi*r*r*h;

printf("圆周长为:

printf("圆面积为:

printf("圆球表面积为:

printf("圆球体积为:

v=%6.2fn",vq);

vz=%6.2fn",vz); printf("圆柱体积为:

return 0;

}

#include

int main()

{

char c1,c2;

printf("请输入两个字符 c1,c2:");

c1=getchar();

c2=getchar();

printf("用 putchar 语句输出结果为:");

putchar(c1);

putchar(c2);

printf("n");

printf("用 printf 语句输出结果为:");

printf("%c %cn",c1,c2);

return 0;

}

#include

int main()

{

int c1,c2;

//整型定义

printf("请输入两个整数 c1,c2:");

scanf("%d,%d",&c1,&c2);

printf("按字符输出结果:n");

printf("%c,%cn",c1,c2);

printf("按 ASCII 码输出结果为:n");

printf("%d,%dn",c1,c2);

return 0;

}#include

int main()

{

char c1,c2;

int i1,i2;

printf("请输入两个字符 c1,c2:");

scanf("%c,%c",&c1,&c2);

i1=c1;

i2=c2;

printf("按字符输出结果:n");

printf("%c,%cn",i1,i2);

printf("按整数输出结果:n");

printf("%d,%dn",c1,c2);

return 0;

}#include

int main()

{

char c1,c2;

//定义字符型变量

//定义整型变量

//赋值给整型变量

//定义为字符型

int i1,i2;

//定义为整型

printf("请输入两个整数 i1,i2:");

scanf("%d,%d",&i1,&i2);

c1=i1;

//将整数赋值给字符变量

c2=i2;

printf("按字符输出结果:n");

printf("%c,%cn",c1,c2);

printf("按整数输出结果:n");

printf("%d,%dn",c1,c2);

return 0;

}

第四章

#include

int main()

{

int a,b,c;

printf("请输入三个整数:");

scanf("%d,%d,%d",&a,&b,&c);

if (a

if (b

printf("max=%dn",c);

else

printf("max=%dn",b);

else if (a

printf("max=%dn",c);

else

printf("max=%dn",a);

return 0;

}#include

int main()

{ int a,b,c,temp,max;

printf("请输入三个整数:");

scanf("%d,%d,%d",&a,&b,&c);

temp=(a>b)?a:b;

/*将 a 和 b 中的大者存入 temp 中*/

/*将 a 和 b 中的大者与 c 比较,取最大者*/ max=(temp>c)?temp:c;

printf("三个整数的最大数是%dn",max);

return 0;

} #include

#include

#define M 1000

int main()

{

int i,k;

printf("请输入一个小于%d 的整数 i:",M);

scanf("%d",&i);

while (i>M)

{printf("输入的数不符合要求,请重新输入一个小于%d 的整数 i:",M);

scanf("%d",&i);

}

k=sqrt(i);

printf("%d 的平方根的整数部分是:%dn",i,k);

return 0;

}

#include

#include

#define

M 1000 int main()

{

int i,k;

printf("请输入一个小于%d 的整数 i:",M);

scanf("%d",&i);

if (i>M)

{printf("输入的数不符合要求,请重新输入一个小于%d 的整数 i:",M);

scanf("%d",&i);

}

k=sqrt(i);

printf("%d 的平方根的整数部分是:%dn",i,k);

return 0;

}

#include

int main()

{ int x,y;

printf("输入 x:");

scanf("%d",&x);

if(x<1)

/* x<1 */

{ y=x;

printf("x=%3d,

y=x=%dn" ,x,y);

}

else

if(x<10)

/* 1=

{ y=2*x-1;

printf("x=%d,

y=2*x-1=%dn",x,y);

}

else /* x>=10 */ { y=3*x-11;

printf("x=%d,

y=3*x-11=%dn",x,y);

}

return

0; }#include

int main()

{

int x,y;

printf("enter x:");

scanf("%d",&x);

y=-1;

if(x!=0)

if(x>0)

y=1;

else

y=0;

printf("x=%d,y=%dn",x,y);

return 0;

}

#include

int main()

{

int x,y;

printf("please enter x:");

scanf("%d",&x);

y=0;

if(x>=0)

if(x>0) y=1;

else y=-1;

printf("x=%d,y=%dn",x,y);

return 0;

}

#include

int main()

{ float score;

char grade;

printf("请输入学生成绩:");

scanf("%f",&score);

while (score>100||score<0)

{printf("n 输入有误,请重输");

scanf("%f",&score);

}

switch((int)(score/10))

{case 10:

case 9: grade='A';break;

case 8: grade='B';break;

case 7: grade='C';break;

case 6: grade='D';break;

case 5:

case 4:

case 3:

case 2:

case 1:

case 0: grade='E';

}

printf("成绩是 %5.1f,相应的等级是%cn ",score,grade);

return 0;

}

#include

#include

int main()

{

int num,indiv,ten,hundred,thousand,ten_thousand,place;

//分别代表个位,十位,百位,千

位,万位和位数

printf("请输入一个整数(0-99999):");

scanf("%d",&num);

if (num>9999)

place=5;

else

if (num>999)

place=4;

else

if (num>99)

place=3;

else

if (num>9)

place=2;

else place=1;

printf("位数:%dn",place); printf("每位数字为:"); ten_thousand=num/10000;

thousand=(int)(num-ten_thousand*10000)/1000;

hundred=(int)(num-ten_thousand*10000-thousand*1000)/100; ten=(int)(num-ten_thousand*10000-thousand*1000-hundred*100)/10; indiv=(int)(num-ten_thousand*10000-thousand*1000-hundred*100-ten*10);

switch(place)

{case 5:printf("%d,%d,%d,%d,%d",ten_thousand,thousand,hundred,ten,indiv);

printf("n 反序数字为:");

printf("%d%d%d%d%dn",indiv,ten,hundred,thousand,ten_thousand);

break;

case 4:printf("%d,%d,%d,%d",thousand,hundred,ten,indiv);

printf("n 反序数字为:");

printf("%d%d%d%dn",indiv,ten,hundred,thousand);

break;

case 3:printf("%d,%d,%d",hundred,ten,indiv);

printf("n 反序数字为:");

printf("%d%d%dn",indiv,ten,hundred);

break;

case 2:printf("%d,%d",ten,indiv);

printf("n 反序数字为:");

printf("%d%dn",indiv,ten);

break;

case 1:printf("%d",indiv);

printf("n 反序数字为:");

printf("%dn",indiv);

break;

}

return

0; }#include

int main()

{

int i;

double bonus,bon1,bon2,bon4,bon6,bon10;

bon1=100000*0.1;

bon2=bon1+100000*0.075;

bon4=bon2+100000*0.05;

bon6=bon4+100000*0.03;

bon10=bon6+400000*0.015; printf("请输入利润 i:");

scanf("%d",&i);

if (i<=100000)

bonus=i*0.1;

else if (i<=200000)

bonus=bon1+(i-100000)*0.075;

else if (i<=400000)

bonus=bon2+(i-200000)*0.05;

else if (i<=600000)

bonus=bon4+(i-400000)*0.03;

else if (i<=1000000)

bonus=bon6+(i-600000)*0.015;

else

bonus=bon10+(i-1000000)*0.01;

printf("奖金是: %10.2fn",bonus);

return 0;

}

#include

int main()

{

int i;

double bonus,bon1,bon2,bon4,bon6,bon10;

int branch;

bon1=100000*0.1;

bon2=bon1+100000*0.075;

bon4=bon2+200000*0.05;

bon6=bon4+200000*0.03;

bon10=bon6+400000*0.015;

printf("请输入利润 i:");

scanf("%d",&i);

branch=i/100000;

if (branch>10) branch=10;

switch(branch)

{ case 0:bonus=i*0.1;break;

case 1:bonus=bon1+(i-100000)*0.075;break;

case 2:

case 3: bonus=bon2+(i-200000)*0.05;break;

case 4:

case 5: bonus=bon4+(i-400000)*0.03;break;

case 6:

case 7:

case 8:

case 9: bonus=bon6+(i-600000)*0.015;break;

case 10: bonus=bon10+(i-1000000)*0.01;

}

printf("奖金是 %10.2fn",bonus);

return 0;

}

#include

int main()

{int t,a,b,c,d; printf("请输入四个数:");

scanf("%d,%d,%d,%d",&a,&b,&c,&d);

printf("a=%d,b=%d,c=%d,d=%dn",a,b,c,d);

if (a>b)

{ t=a;a=b;b=t;}

if (a>c)

{ t=a;a=c;c=t;}

if (a>d)

{ t=a;a=d;d=t;}

if (b>c)

{ t=b;b=c;c=t;}

if (b>d)

{ t=b;b=d;d=t;}

if (c>d)

{ t=c;c=d;d=t;}

printf("排序结果如下: n");

printf("%d

%d

%d

%d

n"

,a,b,c,d);

return 0;

}

#include

int main()

{

int

h=10;

float x1=2,y1=2,x2=-2,y2=2,x3=-2,y3=-2,x4=2,y4=-2,x,y,d1,d2,d3,d4;

printf("请输入一个点(x,y):");

scanf("%f,%f",&x,&y);

d1=(x-x4)*(x-x4)+(y-y4)*(y-y4); /*求该点到各中心点距离*/ d2=(x-x1)*(x-x1)+(y-y1)*(y-y1);

d3=(x-x2)*(x-x2)+(y-y2)*(y-y2);

d4=(x-x3)*(x-x3)+(y-y3)*(y-y3);

if (d1>1 && d2>1 && d3>1 && d4>1) h=0; /*判断该点是否在塔外*/

printf("该点高度为 %dn",h);

return 0;

}

第五章

#include

#include

int main()

{

int sign=1,count=0;

double pi=0.0,n=1.0,term=1.0;

term 代表当前项的值

while(fabs(term)>=1e-8)

次方

{

// 程序中用到数学函数 fabs,应包含头文件 math.n

// sign 用来表示数值的符号,count 用来统计循环次数

// pi 开始代表多项式的值,最后代表π的值, n 代表分母,// 检查当前项 term 的绝对值是否大于或等于 10 的(-6)

pi=pi+term;

n=n+2;

// 把当前项 term 累加到 pi 中

// n+2 是下一项的分母

// sign 代表符号,下一项的符号与上一项符号相反

// 求出下一项的值 term

// count 累加 1

sign=-sign;

term=sign/n;

count++;

}

pi=pi*4;

// 多项式的和 pi 乘以 4,才是π的近似值

// 输出π的近似值

// 输出循环次数

printf("pi=%10.8fn",pi);

printf("count=%dn",count);

return 0;

}

#include

int main()

{

int

p,r,n,m,temp;

printf("请输入两个正整数 n,m:");

scanf("%d,%d,",&n,&m);

if (n

{

temp=n;

n=m;

m=temp;

}

p=n*m;

while(m!=0)

{

r=n%m;

n=m;

m=r;

}

printf("它们的最大公约数为:%dn",n);

printf("它们的最小公约数为:%dn",p/n);

return 0;

}

#include

int main()

{

char c;

int letters=0,space=0,digit=0,other=0;

printf("请输入一行字符:n");

while((c=getchar())!='n')

{

if (c>='a' && c<='z' || c>='A' && c<='Z')

letters++;

else if (c==' ')

space++;

else if (c>='0' && c<='9')

digit++;

else

other++;

}

printf("字母数:%dn 空格数:%dn 数字数:%dn 其它字符数:%dn",letters,space,digit,other);

return 0;

} #include

int main()

{

int a,n,i=1,sn=0,tn=0;

printf("a,n=:");

scanf("%d,%d",&a,&n);

while (i<=n)

{

tn=tn+a; /*赋值后的 tn 为 i 个 a 组成数的值*/

sn=sn+tn; /*赋值后的 sn 为多项式前 i 项之和*/

a=a*10;

++i;

}

printf("a+aa+aaa+...=%dn",sn);

return 0;

}#include

int main()

{double s=0,t=1;

int n;

for (n=1;n<=20;n++)

{

t=t*n;

s=s+t;

}

printf("1!+2!+...+20!=%22.15en",s);

return 0;

} #include

int main()

{

int n1=100,n2=50,n3=10;

double k,s1=0,s2=0,s3=0;

for (k=1;k<=n1;k++) /*计算 1 到 100 的和*/

{s1=s1+k;}

for (k=1;k<=n2;k++) /*计算 1 到 50 各数的平方和*/

{s2=s2+k*k;}

for (k=1;k<=n3;k++) /*计算 1 到 10 的各倒数和*/

{s3=s3+1/k;}

printf("sum=%15.6fn",s1+s2+s3);

return 0;

}#include

int main()

{

int i,j,k,n;

printf("parcissus numbers are ");

for (n=100;n<1000;n++)

{

i=n/100;

j=n/10-i*10;

k=n%10;

if (n==i*i*i + j*j*j + k*k*k)

printf("%d ",n);

}

printf("n");

return 0;

}#define M 1000 /*定义寻找范围*/ #include

int main()

{

int k1,k2,k3,k4,k5,k6,k7,k8,k9,k10;

int i,a,n,s;

for (a=2;a<=M;a++)

/* a 是 2-1000 之间的整数,检查它是否完数 */

/* n 用来累计 a 的因子的个数 */

/* s 用来存放尚未求出的因子之和,开始时等于 a */

/* 检查 i 是否 a 的因子 */

/* 如果 i 是 a 的因子 */

/* n 加 1,表示新找到一个因子 */

/* s 减去已找到的因子,s 的新值是尚未求出的因子之和 */

/* 将找到的因子赋给 k1...k9,或 k10 */

{n=0;

s=a;

for (i=1;i

if (a%i==0)

{n++;

s=s-i;

switch(n)

{case 1:

k1=i;

break;

/* 找出的笫 1 个因子赋给 k1 */

case 2:

k2=i;

break;

/* 找出的笫 2 个因子赋给 k2 */

case 3:

k3=i;

break;

/* 找出的笫 3 个因子赋给 k3 */

case 4:

k4=i;

break;

/* 找出的笫 4 个因子赋给 k4 */

case 5:

k5=i;

break; /* 找出的笫 5 个因子赋给 k5 */

case 6:

k6=i;

break; /* 找出的笫 6 个因子赋给 k6 */

case 7:

k7=i;

break;

/* 找出的笫 7 个因子赋给 k7 */

case 8:

k8=i;

break;

/* 找出的笫 8 个因子赋给 k8 */

case 9:

k9=i;

break;

/*找出的笫 9 个因子赋给 k9 */

case 10:

k10=i;

break;

/* 找出的笫 10 个因子赋给 k10 */

}

}

if (s==0)

{

printf("%d ,Its factors are ",a);

if (n>1)

printf("%d,%d",k1,k2);

/* n>1 表示 a 至少有 2 个因子 */

/* n>2 表示至少有 3 个因子,故应再输出一个 if (n>2)

printf(",%d",k3);

因子 */

if (n>3)

printf(",%d",k4);

/* n>3 表示至少有 4 个因子,故应再输出一个

因子 */

if (n>4)

printf(",%d",k5);

/* 以下类似 */

if (n>5)

printf(",%d",k6);

if (n>6)

printf(",%d",k7);

if (n>7)

printf(",%d",k8);

if (n>8)

printf(",%d",k9);

if (n>9)

printf(",%d",k10);

printf("n");

}

}

return

0; }#include

int main()

{int m,s,i;

for (m=2;m<1000;m++)

{s=0;

for (i=1;i

if ((m%i)==0) s=s+i;

if(s==m)

{printf("%d,its factors are ",m);

for (i=1;i

if (m%i==0) printf("%d ",i);

printf("n");

}

}

return 0;

}#include

int main()

{

int i,n=20;

double a=2,b=1,s=0,t;

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

{

s=s+a/b;

t=a,

a=a+b,

b=t;

}

printf("sum=%16.10fn",s);

return 0;

}#include

int main()

{

double sn=100,hn=sn/2;

int n;

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

{

sn=sn+2*hn; /*第 n 次落地时共经过的米数*/

hn=hn/2;

}

/*第 n 次反跳高度*/

printf("第 10 次落地时共经过%f 米n",sn);

printf("第 10 次反弹%f 米n",hn);

return 0;

}#include

int main()

{

int day,x1,x2;

day=9; x2=1;

while(day>0)

{x1=(x2+1)*2; /*第 1 天的桃子数是第 2 天桃子数加 1 后的 2 倍.*/

x2=x1;

day--;

}

printf("total=%dn",x1);

return 0;

} #include

#include

int main()

{

float a,x0,x1;

printf("enter a positive number:");

scanf("%f",&a);

x0=a/2;

x1=(x0+a/x0)/2;

do

{x0=x1;

x1=(x0+a/x0)/2; }while(fabs(x0-x1)>=1e-5);

printf("The square root of %5.2f is %8.5fn",a,x1);

return 0;

} #include

#include

int main() {double

x1,x0,f,f1;

x1=1.5;

do

{x0=x1; f=((2*x0-4)*x0+3)*x0-6;

f1=(6*x0-8)*x0+3;

x1=x0-f/f1; }while(fabs(x1-x0)>=1e-5);

printf("The root of equation is %5.2fn",x1);

return 0;

} #include

#include

int main()

{float x0,x1,x2,fx0,fx1,fx2;

do

{printf("enter x1 & x2:");

scanf("%f,%f",&x1,&x2);

fx1=x1*((2*x1-4)*x1+3)-6;

fx2=x2*((2*x2-4)*x2+3)-6;

}while(fx1*fx2>0);

do

{x0=(x1+x2)/2;

fx0=x0*((2*x0-4)*x0+3)-6;

if ((fx0*fx1)<0)

{x2=x0;

fx2=fx0;

}

else

{x1=x0;

fx1=fx0;

}

}while(fabs (fx0)>=1e-5);

printf("x=%6.2fn",x0);

return 0;

}

#include

int main()

{int i,j,k;

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

(j=0;j<=2-i;j++)

printf(" ");

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

printf("*");

printf("n");

}

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

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

printf(" ");

for (k=0;k<=4-2*i;k++)

printf("*");

printf("n");

}

return 0;

}

#include

int main()

{

char i,j,k;

/*是 a 的对手;j 是 b 的对手;k 是 c 的对手*/

for (i='x';i<='z';i++)

for (j='x';j<='z';j++)

if (i!=j)

for (k='x';k<='z';k++)

if (i!=k && j!=k)

if (i!='x' && k!='x' && k!='z') printf("A--%cnB--%cnC--%cn",i,j,k);

return 0;

}

第六章

#include

#include

int main()

{int i,j,n,a[101];

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

a[i]=i;

a[1]=0;

for (i=2;i

for (j=i+1;j<=100;j++)

{if(a[i]!=0 && a[j]!=0)

if (a[j]%a[i]==0)

a[j]=0;

}

printf("n");

for (i=2,n=0;i<=100;i++)

{ if(a[i]!=0)

{printf("%5d",a[i]);

n++;

}

if(n==10)

{printf("n");

n=0;

}

}

printf("n");

return 0;

}#include

int main()

{int i,j,min,temp,a[11];

printf("enter data:n");

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

{printf("a[%d]=",i);

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

}

printf("n");

printf("The orginal numbers:n");

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

printf("%5d",a[i]);

printf("n");

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

{min=i;

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

if (a[min]>a[j]) min=j;

temp=a[i];

a[i]=a[min];

a[min]=temp;

}

printf("nThe sorted numbers:n");

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

printf("%5d",a[i]);

printf("n");

return 0;

}

#include

int main()

{

int a[3][3],sum=0;

int i,j;

printf("enter data:n");

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

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

scanf("%3d",&a[i][j]);

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

sum=sum+a[i][i];

printf("sum=%6dn",sum);

return 0;

}

#include

int main()

{ int a[11]={1,4,6,9,13,16,19,28,40,100};

int temp1,temp2,number,end,i,j;

printf("array a:n");

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

printf("%5d",a[i]);

printf("n");

printf("insert data:");

scanf("%d",&number);

end=a[9];

if (number>end)

a[10]=number;

else

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

{if (a[i]>number)

{temp1=a[i];

a[i]=number;

for (j=i+1;j<11;j++)

{temp2=a[j];

a[j]=temp1;

temp1=temp2;

}

break;

}

}

}

printf("Now array a:n");

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

printf("%5d",a[i]);

printf("n");

return 0;

}

#include

#define N 5

int main()

{ int a[N],i,temp;

printf("enter array a:n");

for (i=0;i

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

printf("array a:n");

for (i=0;i

printf("%4d",a[i]);

for (i=0;i

{ temp=a[i];

a[i]=a[N-i-1];

a[N-i-1]=temp;

}

printf("nNow,array a:n");

for (i=0;i

printf("%4d",a[i]);

printf("n");

return 0;

}

#include

#define N 10

//循环的作用是将对称的元素的值互换

int main()

{ int i,j,a[N][N];

for (i=0;i

{a[i][i]=1;

a[i][0]=1;

}

for (i=2;i

for (j=1;j<=i-1;j++) a[i][j]=a[i-1][j-1]+a[i-1][j];

for (i=0;i

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

printf("%6d",a[i][j]);

printf("n");

}

printf("n");

return 0;

}

#include

int main()

{ int a[15][15],i,j,k,p,n;

p=1;

while(p==1)

{printf("enter n(n=1--15):");

scanf("%d",&n);

if ((n!=0) && (n<=15) && (n%2!=0))

p=0;

}

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

(j=1;j<=n;j++)

a[i][j]=0;

j=n/2+1;

a[1][j]=1;

for (k=2;k<=n*n;k++)

{i=i-1;

j=j+1;

if ((i<1) && (j>n))

{i=i+2;

j=j-1;

}

else

{if (i<1) i=n;

if (j>n) j=1;

}

if (a[i][j]==0)

a[i][j]=k;

else

{i=i+2;

j=j-1;

a[i][j]=k;

}

}

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

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

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

printf("n");

}

return 0;

}

#include

#define N 4

#define M 5 /* 数组为 4 行 5 列 */ int main()

{

int i,j,k,a[N][M],max,maxj,flag;

printf("please input matrix:n");

for (i=0;i

/* 输入数组 */

for (j=0;j

scanf("%d",&a[i][j]);

for (i=0;i

{max=a[i][0];

/* 开始时假设 a[i][0]最大 */

/* 将列号 0 赋给 maxj 保存 */

/* 找出第 i 行中的最大数 */

maxj=0;

for (j=0;j

if (a[i][j]>max)

{max=a[i][j];

/* 将本行的最大数存放在 max 中 */

/* 将最大数所在的列号存放在 maxj 中 */ maxj=j;

}

flag=1;

/* 先假设是鞍点,以 flag 为 1 代表 */

for (k=0;k

if (max>a[k][maxj])

/* 将最大数和其同列元素相比 */

/* 如果 max 不是同列最小,表示不是鞍点令 flag1 为 0 {flag=0;

*/

continue;}

if(flag)

/* 如果 flag1 为 1 表示是鞍点 */

/* 输出鞍点的值和所在行列号 */ {printf("a[%d][%d]=%dn",i,maxj,max);

break;

}

}

if(!flag)

/* 如果 flag 为 0 表示鞍点不存在 */

printf("It is not exist!n");


本文标签: 输入 因子 输出 整数 结果