求<c语言程序设计>的答案

求<c语言程序设计>的答案,第1张

(第一题)#include <stdioh>

void main()

{

int gy(int m, int n);

int x,y,max, min;

printf("请输入两个大于0的正整数,以空格或者回车间隔:\n");

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

while(x<1 || y<1)

{

printf("输入数据不正确,请重新输入。\n");

printf("请输入两个大于0的正整数,以空格或者回车间隔:\n");

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

}

max=gy(x,y);

min=xy/max;

printf("%d与%d的最大公约数是:%d,最小公倍数是:%d\n",x,y,max,min);

}

int gy(int m, int n)

{

int max, t;

while(m%n != 0) // while(m%n)

{

t=n; n=m%n; m=t;

}

max=n;

return max;

}

第二题#include <stdioh>

#include <mathh>

void main()

{

void root(double a, double b, double c);

double a, b, c;

printf("请输入一元二次方程的系数,用空格或者回车间隔:\n");

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

root(a,b,c);

}

void root(double a, double b, double c)

{

double disc, x1, x2, real , imag;

disc = bb-4ac;

if(disc>0)

{

x1 = (-b+sqrt(disc))/(2a);

x2 = (-b-sqrt(disc))/(2a);

printf("方程有两个实根,分别是:%f 与 %f\n", x1, x2);

}

else if(disc==0)

{

x1 = (-b)/(2a);

printf("方程有一个实根,它是:%f\n ", x1);

}

else

{

real=(-b)/(2a);

imag=sqrt(-disc)/(2a);

printf("方程有两个虚根,分别是:%f+%fi, %f-%fi\n", real,imag,real,imag);

}

}

测试1:请输入一元二次方程的系数,用空格或者回车间隔:1 2 1

方程有一个实根,它是:-1000000

测试2:请输入一元二次方程的系数,用空格或者回车间隔:1 6 5

方程有两个实根,分别是:-1000000 与 -5000000

测试3:请输入一元二次方程的系数,用空格或者回车间隔:1 1 1

方程有两个虚根,分别是:-0500000+0866025i, -0500000-0866025i

第三题#include <stdioh>

#include <mathh>

void main()

{

int isprime(int n);

int n;

scanf("%d",&n);

while(n<2)

{

printf("Please reinput(n>=2):");

scanf("%d",&n);

}

if(isprime(n))

printf("%d是素数。\n",n);

else

printf("%d不是素数。\n",n);

}

int isprime(int n)

{

int i,k=sqrt(n);

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

{

if(n%i==0)

return 0;

}

return 1;

}

第四题#include <stdioh>

#include <mathh>

void main()

{

void printA(int a[3][3]);

void reverse(int a[3][3]); //转置函数的声明

int a[3][3]={{1,2,3},{4,5,6},{7,8,9}};

printf("原二维数组:\n");

printA(a);

reverse(a); //函数转置

printf("转置后的数组:\n");

printA(a);

}

void printA(int a[3][3])

{

int i,j;

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

{

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

{

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

}

printf("\n");

}

}

void reverse(int a[3][3]) //函数转置的定义

{

int i,j,t;

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

{

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

{

t=a[i][j];

a[i][j]=a[j][i];

a[j][i]=t;

}

}

}

第五题#include <stdioh>

#include <stringh>

void main()

{

char str[30];

void fanxu(char p);

printf("请输入一个字符串:");

gets(str);

printf("进行反序\n");

fanxu(str);

printf("反序后的字符串:");

puts(str);

}

void fanxu(char p)

{

int len=strlen(p);

char q,c;

q=p+len-1; //字符串最后一个字符位置

for(;p<q;p++,q--)

{

c=p; p=q; q=c;

}

}

第六题#include <stdioh>

#include <stringh>

void main()

{

char str1[60],str2[30];

void str_copy(char p, char q);

printf("请输入第一个字符串:");

gets(str1);

printf("请输入第二个字符串:");

gets(str2);

str_copy(str1, str2);

printf("连接后的字符串:");

puts(str1);

}

void str_copy(char p, char q)

{

for(;p!='\0';p++);

for(;q!='\0';p++,q++)

{

p=q;

}

p='\0';

}

(0808)#include <stdioh>

#include <stringh>

void main()

{

char str[80];

void insert(char str[]); //插入空格的函数

printf("请输入一个字符串:");

gets(str);

insert(str); //插入空格

puts(str); //输出字符串

}

void insert(char str[])

{

int len, i;

len=strlen(str);

for(i=len; i>0; i--) // 设置空格

{

str[2i]=str[i];

str[2i-1]=' ';

}

}

(0809)#include <stdioh>

int letter; //字母个数

int digit; //数字个数

int space; //空格个数

int others; //其它字母个数

void main()

{

void count(char str[]); //统计个数的函数的声明

char s[81];

printf("请输入一个字符串:");

gets(s);

letter=0; digit=0;

space=0; others=0;

count(s);

printf("字符串中共有 %d 个字母,%d 个数字,%d 个空格,%d个其它字母。\n",letter,digit,space,others);

}

void count(char str[]) //统计个数的函数的定义

{

int i;

char c;

for(i=0; str[i]!='\0';i++)

{

c=str[i];

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

{ letter++; }

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

{ digit++; }

else if(c==' ')

{ space++; }

else

{ others++; }

}

}

(0810)#include <stdioh>

#include <stringh>

void main()

{

int i;

char line[81];

int alphabetic(char c); //判断一个字符是空格还是其它字母

int longest(char str[]);//寻找最长单词的起始位置

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

gets(line);

printf("最长的字符串是:");

for(i=longest(line); alphabetic(line[i]); i++)

{ printf("%c",line[i]);}

printf("\n");

}

int alphabetic(char c) //如果为空格返回0,其它字母返回1

{

if(c!=' ')

return 1;

else

return 0;

}

int longest(char str[])

{

int len=0; // 记录每一个单词的长度

int length=0; // 记录最长单词的长度

int flag=1; // 其值为0时表示当前位置处于字符串中,为1时表示当前位置为空格

int place=0; // 记录最长字符串(单词)的起始位置

int point; // 每个字符串的起始位置

for(int i=0; i<=strlen(str); i++)

{

if(alphabetic(str[i])) //如果当前位置为非空格

{

if(flag) //如果前一字符为空格

{

point = i; // 设置当前单词的起始位置

flag = 0; // flag设为0,表示处于单词中

}

else //如果前一字符为非空格

{ len++; } // 单词的长度加1

}

else //当前位置为空格

{

flag = 1; //flag设为1,表示当前位置为空格

if(len >= length) //如果最近单词的长度大于最长长度

{

length = len;

place = point; //设置最长单词的起始位置

len = 0; //len归0,重新开始计算单词的长度

}

}

}

return place;

}

(0811)#include <stdioh>

#include <stringh>

void main()

{

void inputNum(int a[], int n);

void outputNum(int a[], int n);

void bubble(int a[], int n);

int a[11], n;

printf("请输入你要排序的数的个数:");

scanf("%d",&n);

inputNum(a,n);

outputNum(a,n);

bubble(a,n);

printf("从小到大排序为:\n");

outputNum(a,n);

}

void inputNum(int a[], int n)

{

int i;

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

{

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

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

}

}

void outputNum(int a[], int n)

{

int i;

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

{

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

}

printf("\n");

}

void bubble(int a[], int n)

{

int i,j,t;

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

{

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

{

if(a[j]>a[j+1])

{ t=a[j]; a[j]=a[j+1]; a[j+1]=t; }

}

}

}

(0813)#include <stdioh>

void main()

{

double lrd(int, double);

double x;

int n;

printf("请输入n阶勒让德多项式的阶数:\n");

scanf("%d",&n);

printf("请输入x的值:\n");

scanf("%lf",&x);

printf("参数为%f 的 %d 阶勒让德多项式的值为 %f\n",x,n,lrd(n,x));

}

double lrd(int n, double x)

{

if(n==0)

return 1;

else if(n==1)

return x;

else

return ((2n-1)x - lrd(n-1,x) -(n-1)lrd(n-2,x))/n;

}

/

测试1:请输入n阶勒让德多项式的阶数:0请输入x的值:9999参数为99990000 的 0 阶勒让德多项式的值为 1000000

测试2:请输入n阶勒让德多项式的阶数:1请输入x的值:9999

参数为99990000 的 1 阶勒让德多项式的值为 99990000

测试3:请输入n阶勒让德多项式的阶数:2

请输入x的值:9999 参数为99990000 的 2 阶勒让德多项式的值为 99490000

测试4:请输入n阶勒让德多项式的阶数:10

请输入x的值:11

参数为1100000 的 10 阶勒让德多项式的值为 0888677

(0817)#include <stdioh>

void main()

{

int num;

void convert(int num); // 转换为字符串的函数的声明

printf("请输入一个整数:\n");

scanf("%d",&num);

printf("转换成字符串:");

if(num<0)

{

putchar('-');

num = -num;

}

convert(num);

printf("\n");

}

void convert(int n)

{

int i;

if((i = (n/10)) != 0)

{

convert(i);

}

putchar(n%10 + '0');

}

(0818)#include <stdioh>

int d[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};

void main()

{

int year,month,day;

int days;

int count(int year,int month, int day);

int leap(int y);

printf("请输入年份:");

scanf("%d",&year);

while(year<=0)

{

printf("年份不能为负,请重新输入:");

scanf("%d",&year);;

}

if(leap(year)) //如果为闰年,2月份的天数为29

{ d[2]=29; }

printf("输入月份:");

scanf("%d",&month);

while(month<1 || month>12)

{

printf("月份在1月和12月之间,你的输入有误,请重新输入:");

scanf("%d",&month);

}

printf("输入日数:");

scanf("%d",&day);;

while(day<1 || day >d[month])

{

printf("日数应在1和%d之间,请重新输入:",d[month]);

scanf("%d",&day);

}

days=count(year,month,day);

printf("%d年%d月%d日是该年的第%d天\n",year,month,day,days);

}

int leap(int y)

{

if(y%4==0 && y%100!=0 || y%400==0)

return 1;

else

return 0;

}

int count(int year,int month, int day)

{

int i,days=0;

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

{ days += d[i]; }

days+=day;

return days;

}

(08050)#include <stdioh>

#include <stringh>

void main()

{

char str[30];

void fanxu(char str[]);

printf("请输入一个字符串:");

gets(str);

printf("进行反序\n");

fanxu(str);

printf("反序后的字符串:");

puts(str);

}

void fanxu(char str[])

{

int len=strlen(str);

int i,j;

char c;

i=0; j=len-1;//i,j分别存储第一个字符和最后一个字符的下标

for(;i<j; i++,j--)

{

c=str[i]; str[i]=str[j]; str[j]=c;

}

}

(08051)#include <stdioh>

#include <stringh>

void main()

{

char str[30];

void fanxu(char s[]);

printf("请输入一个字符串:");

gets(str);

printf("进行反序\n");

fanxu(str);

printf("反序后的字符串:");

puts(str);

}

void fanxu(char s[])

{

int len=strlen(s);

int i;

char c;

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

{

c=s[i];

s[i]=s[len-i-1];

s[len-i-1]=c;

}

}

(08061)#include <stdioh>

#include <stringh>

void main()

{

char str1[60],str2[30];

void str_copy(char s1[], char s2[]);

printf("请输入第一个字符串:");

gets(str1);

printf("请输入第二个字符串:");

gets(str2);

str_copy(str1, str2);

printf("连接后的字符串:");

puts(str1);

}

void str_copy(char s1[], char s2[])

{

int i,j;

for(i=0;s1[i];i++); // s1[i]!='\0'

for(j=0;s1[i]=s2[j];i++,j++);

// (s1[i]=s2[j])!='\0'

}

(08110)#include <stdioh>

#include <stringh>

void main()

{

void inputNum(char a[], char n);

void outputNum(char a[], char n);

void bubble(char a[], char n);

char a[11], n;

printf("请输入你要排序的数的个数:");

scanf("%d",&n);

inputNum(a,n);

outputNum(a,n);

bubble(a,n);

printf("从小到大排序为:\n");

outputNum(a,n);

}

void inputNum(char a[], char n)

{

char i;

printf("请连续输入%d个字符:",n);

fflush(stdin); //一般在输入字符或者字符串之前要清空输入缓冲区

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

{

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

}

}

void outputNum(char a[], char n)

{

char i;

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

{

printf("%2c",a[i]);

}

printf("\n");

}

void bubble(char a[], char n)

{

char i,j,t;

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

{

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

{

if(a[j]>a[j+1])

{ t=a[j]; a[j]=a[j+1]; a[j+1]=t; }

}

}

}

(08112)#include <iostreamh>

#include <iomaniph>

void main()

{

void inputNum(int a[], int n);

void outputNum(int a[], int n);

void bubble(int a[], int n);

int a[11], n;

cout<<"请输入你要排序的数的个数:";

cin>>n;

while(n<1 || n>10)

{

cout<<"请重新输入,(1<=n<=10):";

cin>>n;

}

inputNum(a,n);

outputNum(a,n);

bubble(a,n);

cout<<"从小到大排序为:\n";

outputNum(a,n);

}

void inputNum(int a[], int n)

{

int i;

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

{

cout<<"a["<<i<<"]=";

cin>>a[i];

}

}

void outputNum(int a[], int n)

{

int i;

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

{

cout<<setw(6)<<a[i];

}

cout<<endl;

}

void bubble(int a[], int n)

{

int i,j,t;

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

{

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

{

if(a[j]>a[j+1])

{ t=a[j]; a[j]=a[j+1]; a[j+1]=t; }

}

}

}

(08181)#include <iostreamh>

#include <iomaniph>

int d[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};

void main()

{

int year,month,day;

int days;

int count(int year,int month, int day);

int leap(int y);

cout<<"请输入年份:";

cin>>year;

while(year<=0)

{

cout<<"年份不能为负,请重新输入:";

cin>>year;

}

if(leap(year)) //如果为闰年,2月份的天数为29

{ d[2]=29; }

cout<<"输入月份:";

cin>>month;

while(month<1 || month>12)

{

cout<<"月份在1月和12月之间,你的输入有误,请重新输入:";

cin>>month;

}

cout<<"输入日数:";

cin>>day;

while(day<1 || day >d[month])

{

cout<<"日数应在1和"<<d[month]<<"之间,请重新输入:"<<endl;

cin>>day;

}

days=count(year,month,day);

cout<<year<<"年"<<month<<"月"<<day<<"日是该年的第"<<days<<"天\n";

}

int leap(int y)

{

if(y%4==0 && y%100!=0 || y%400==0)

return 1;

else

return 0;

}

int count(int year,int month, int day)

{

int i,days=0;

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

{ days += d[i]; }

days+=day;

return days;

}

以下是用 C 语言计算实心圆环面积的代码:

在上面的代码中,我们使用了 mathh 库中的函数来计算圆环的面积。具体来说,我们使用了 r1 和 r2 分别表示外半径和内半径,然后使用 PI 表示圆周率。接着,我们使用 (r1  r1) / 20f 和 (r2  r2) / 20f 分别计算外圆和内圆的半径,然后乘以圆周率即可得到圆环的面积。最后,我们使用 printf 函数将计算结果输出到控制台上。

区别:C语言第一版主要是基本的语言结构,支持简单的程序设计,它的变量类型仅限于基本数据类型(整数、浮点数、字符)。而第3版则大大拓展了C语言的功能,新增了结构体、指针、函数嵌套、递归等特性,使得程序设计能力更强,代码也更加简洁。

大学学习资料免费下载网 有

在 其他公共课程 版块

标题:

C程序设计题解与上机指导 答案

还有很多相关资料:

谭浩强编《C语言程序设计》视频教程

C语言程序设计课件_完整版

谭浩强C语言程序设计习题参考解答

C程序设计题解与上机指导 答案

谭浩强编《C语言程序设计》(txt\word\pdf电子书+纸质书)

谭浩强《C程序设计题解与上机指导》(电子书+纸质书)

下载不用积分,资料很多,自己去下载吧

1n=0 a=0

从右往左开始运算

n%=(n%=2)--->n%=(7%=2)---> n%=1--->n = 0

a+=a-=a=a 这个语句不同的编译器的结果是不一样的。在vc下因为执行了一次a -= a的 *** 作,所以a=0

2m=17

首先执行(--y==x++)的时候,x的值变为16了,y的值变成19。判断 19==15 显然是false,再执行++x后返回17。

3输出1,0

先执行a+b和a-b,显然28 != 2,所以为真,值为1

同理 1314 <= 04 ,为假,值为0

4

#define pi 31415926

float GetVolume(const float& r,const float& h)

{

return pirrh/3;

}

我们可以用C语言编写一个程序来求解这个问题。具体思路如下:

根据题目条件,我们需要找出满足x<y<z的三个整数,使得它们的平方和等于55的平方。

由于x、y、z均为正整数,因此我们可以枚举x、y、z的取值范围(比如从1到30),并在其中寻找符合条件的解。

对于每组可能的解,我们可以计算它们的平方和,并与55的平方进行比较,如果相等,则输出这组解。

下面是一个简单的C语言程序,实现了上述思路:

在程序中,我们使用了三重循环来枚举x、y、z的取值范围,并使用if语句判断它们是否符合条件。如果符合条件,则输出它们的值,并将计数器加1。最后,程序输出符合条件的解的数量。

在本题中,由于我们需要求出所有符合条件的解,因此程序的运行时间可能会比较长。实际上,通过手工计算可以得知,满足条件的解只有一组,即x=5,y=7,z=9。因此,我们也可以在程序中对y和z的取值范围进行限制,从而提高程序的效率。

---——————————————————————————

#include <stdioh>

int main() {

int x, y, z;

int count = 0; // 计数器,记录符合条件的解的数量

for (x = 1; x <= 30; x++) {

for (y = x+1; y <= 30; y++) {

for (z = y+1; z <= 30; z++) {

if (xx + yy + zz == 5555) {

printf("%d %d %d\n", x, y, z);

count++;

}

}

}

}

printf("共有%d组解。\n", count);

return 0;

}

《C语言程序设计》作业与思考题解答

说明:习题中P119:27 表示《C/C++上机实践及习题选解》中第119页的27题,其它以此类推,书后有解答。非《C/C++上机实践及习题选解》中的习题提供习题参考答案。

习题解答

作业一

1.合法的标识符: a12 A21 sum2 _fun C_program

不合法的标识符:f(x) $a21 21a while tan@sohucom

2

main( )

{ int i, j, s;

i=2; j=3;

s=ij;

printf(“ %d %d=%d”,i,j,s)

}

作业二

1指出下列哪些为C语言正确的整型(int)常量、实型(float)常量、字符型(char)常量?

正确的整型(int)常量:0 -325 128 03456

正确的实型(float)常量: 00 2 12e-3 5e2

正确的字符型(char)常量: ‘b’ ‘104’ ‘108’ ‘ ’ ‘8’

2表达式的结果 (1) 1

(2) 0

(4) 0

(5) 95

(9) ‘A’

(11) 2

(12) 45

3 Y=sin(2x)+(a+b)/(ab)/(1+a/b)+aa/2

4.设m为整数,用逻辑表达式表示:能同时被3与7整除或者被5除余2且小于100的整数。

m%3= =0 && m%7= =0 || m%5= =2 && m<100

作业三

1.华氏温度通过公式C=5/9(f-32)转换成摄氏温度。试编程并上机调试运行:从键盘上输入华氏温度,利用公式计算后输出摄氏温度(要求:保留一位小数;记录调试过程中遇到的问题及解决方法)。

#include

main( )

{ float f,c;

scanf(“%f”,&f);

c=50/9(f-32);

printf(“c=%1f”,c);

}

2

用IF语句:

#include

#include

main( )

{ float x,y;

scanf(“%f”,&x);

if (x<0) y=fabs(x);

else if (x<10) y=x;

else if (x<20) y=3-x/5;

else if (x<40) y=3x-10;

else y=0;

printf(“y=%f’,y);

}

用switch 语句:

#include

#include

main( )

{ float x,y;

scanf(“%f”,&x);

if (x<0) y=fabs(x);

else switch ( int(x/10) )

{ case 0: y=x; break;

case 1: y=3-x/5;break;

case 2,3: y=3x-10; break;

defaut y=0;

}

printf(“y=%f’,y);

}

3 解答见P151;

4.程序如下:

#include

#include

main()

{

int i=0;

char ch;

ch=getchar();

while (ch!=' ')

{ if (ch=='(') i++;

if (ch==')') i--;

if (i<0) break;

ch=getchar();

}

if (i==0) printf("(与)匹配") ;

else if (i<0) printf(" 缺) ") ;

else printf("缺少)");

}

5 程序如下:

#include

main()

{

int i,j,k,m=0;

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

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

{ k=100-i10-j5;

if (k>0) { printf(" i=%-3dj=%-3dk=%-3d",i,j,k);

m++;

if (m%4==0) putchar(' ');

}

}

printf(" m=%d ",m);

}

6 在横线上填写合适语句,完善程序,使之完成如下功能:从键盘上输入一个不多于7位的正整数,统计其中2的个数,并求各位数字中的最小数。

#include

main( )

{int count,min,temp;

long n;

min=9; count=0;

scanf( “%ld” ,&n);

do

{ temp= n % 10 ;

if (temp= =2) count++;

if (min>temp) min=temp;

n=n/10;

}while ( n );

printf(“count=%d,min=%d”,count,min)

}

作业四

1.p128: 46 解答见p156

2 p128: 411 解答见p158

3编写一递归函数计算mn ,并从键盘输入m,n的值(如4,3),求mn 的值(上机调试)。

funm_n(int m,int n)

{

int y;

if (n==1) y=m;

else y=mfunm_n(m,--n);

return y;

}

main()

{int m,n,y;

printf("Input integer(m,n):");

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

y=funm_n(m,n);

printf(" %d^%-d=%-d",m,n,y);

}

4P128: 412 (3); 答案:12345678

5.求3-100中的素数,要求编写一函数来判断某数是否为素数。

main()

{

int prime,i,n=0;

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

{ prime=prime_num(i);

if (prime) { if (n%10==0) printf(" ");printf("%4d",prime);n++;}

}

}

prime_num(int m)

{ int k=2,r;

do {

r=m % k;

if (r==0) break;

k++;

}while(k<m); p=""> </m);>

if (r!=0) return m;

else return 0;

}

6 结果如下:

main0:x=12,y=2

fun: x=6,y=25

main:x=12,y=2

fun:x=7,y=26

main:x=12,y=2

作业五

1从键盘上输入一串英文字符(不含空格与其他字符),统计每个字符的数目,并输出字母及相应的数目。

#include

#include

main()

{

int i=0,c[52]={0},m=0;

char str[80];

printf("Input a string:");

scanf("%s",str);

while (str[i])

{ if (str[i]>='A' && str[i] <='Z') c[str[i]-'A']++;

if (str[i]>='a' && str[i] <='z') c[str[i]-'a'+26]++;

i++;

}

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

if (c[i]){ if (m%8==0) putchar(' ');m++;

printf("%c:%-d ",i+'A',c[i]);

}

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

if (c[i+26]){if (m%8==0) putchar(' ');m++;

printf("%c:%-d ",i+'a',c[i+26]);

}

}

2 P132: 515 程序见p167

3.从键盘上输入8个数,用选择法按由大到小的顺序排列并输出,要求用指针实现。

#include

#include

main()

{

int data[8],i,p1,p2,temp;

p1=data;

printf("Input 8 numbers:");

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

{ scanf("%d",p1);/ 或 &(p1) / ;

p1++;

}

for (p1=data;p1<data+8-1;p1++) p=""> </data+8-1;p1++)>

for (p2=p1+1;p2<data+8;p2++) p=""> </data+8;p2++)>

if (p1<p2){ temp=p1; p1=p2; p2=temp;}

for (i=0,p1=data;i<8;i++,p1++)

printf("%6d",p1 ) ;

}

4.从键盘上输入一个4 4整数矩阵,以主对角线()为对称轴,将左下角元素中较大元素代替右上角对应元素,并将右上角元素(含对角线元素)输出。

#include

#include

main()

{

int d[4][4],i,j,temp;

printf("Input 16 numbers:");

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

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

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

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

for (j=0;j<i;j++) p=""> </i;j++)>

if (d[i][j]>d[j][i]) d[j][i]=d[i][j];

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

{ printf(" ");

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

if (j>=i) printf("%6d",d[i][j] ) ;

else printf("%6c",' ') ;

}

}

5.盘上输入两个字符串a,b,下面程序将a,b的对应字符中的较大者存放在数组c的对应位置上,填空完善之。

#include

#include

main( )

{int k=0;

char a[80],b[80],c[80]={‘’},p,q;

p=a; q=b;

gets(a); gets(b);

while (p!=0 || q!=0 )

{ if ( p!=0 ) c[k]=p;

else c[k]=q;

p++; q++; k++;

if ( p !=0 ) strcat(c,p);

else strcat(c,q);

puts(c);

}

作业六

1.P134:65 程序见p178

2.P135:67 程序见p181

3.P134:618 程序见p196

以上就是关于求<c语言程序设计>的答案全部的内容,包括:求<c语言程序设计>的答案、C语言编程计算实心圆环的面积,已知外半径为25cm,内半径为15cm.要求圆周率用符号常量PI表示、c语言程序设计第一版和第3版有什么区别等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9327515.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存