c语言5版第10章答案,第10章 指 针 参考答案 c语言(1)

10.1 输入3个整数,按由小到大的顺序输出。

解:程序如下:(xt10-1.c)

#include

main()

{ intn1,n2,n3;

int *p1,*p2,*p3;

printf("Input three integers n1,n2,n3: ");

scanf("%d,%d,%d",&n1,&n2,&n3);

p1=&n1;

p2=&n2;

p3=&n3;

if(n1>n2) swap(p1,p2);

if(n1>n3) swap(p1,p3);

if(n2>n3) swap(p2,p3);

printf("Now, the order is: %d,%d,%d\n",n1,n2,n3);

}

swap(int *p1,int *p2)

{ int p;

p=*p1;*p1=*p2;*p2=p;

}

运行结果如下:

Input three integers n1,n2,n3: 34,21,25↙

Now, the order is: 21,25,34

10.2输入3个字符串,按由小到大的顺序输出。

解:程序如下:(xt10-2.c)

#include

#include

main()

{ char*str1[20],*str2[20],*str3[20];

char swap();

printf("Input three line:\n");

gets(str1);

gets(str2);

gets(str3);

if(strcmp(str1,str2)>0) swap(str1,str2);

if(strcmp(str1,str3)>0) swap(str1,str3);

if(strcmp(str2,str3)>0) swap(str2,str3);

printf("Now, the order is:\n");

printf("%s\n%s\n%s\n",str1,str2,str3);

}

char swap (char *p1,char*p2)/*交换两个字符串*/

{ char*p[20];

strcpy(p,p1); strcpy(p1,p2); strcpy(p2,p);

}

运行结果如下:

Input three lines:

I study very hard.↙

C language is very interesting.↙

He is a professor.↙

Now, the order is:

C language is very interesting.

He is a professor.

I study very hard.

10.3 输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。写3个函数:(1)输入10个数;(2)进行处理;(3)输出10个数。

解:输入输出函数的N-S图见图10.1。。

序如下:(xt10-3.c)

#include

main()

{ intnumber[10];

input(number);

max_min_value(number);

output(number);

}

input(int number[10])

{ inti;

printf("Input 10 numbers: ");

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

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

}

max_min_value(int array[10])

{ int*max,*min,*p,*array_end;

array_end=array+10;

max=min=array;

for(p=array+1;p

if(*p>*max) max=p;

else if(*p

*p=array[0]; array[0]=*min; *min=*p;

*p=array[9];array[9]=*max;*max=*p;

return;

}

output(int array[10])

{ int*p;

printf("Now, they are: ");

for(p=array;p<=array+9;p++)

printf("%d ",*p);

}

运行结果如下:

Input 10 numbers: 32 24 56 78 1 98 36 44 29 6↙

Now, they are: 1 24 56 78 32 6 36 44 29 98

10.4 有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面m个数,见图10.3。写一函数实现以上功能,在主函数中输入n个整数,并输出调整后的n个数。

解:程序如下:(xt10-4.c)

#include

main()

{ intnumber[20],n,m,i;

void move(int array[20],int n,int m);

printf("How many numbers? ");/* 共有多少个数 */

scanf("%d",&n);

printf("Input %d numbers: \n",n);/* 输入n个数 */

for(i=0;i

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

printf("How many place you want to move? "); /* 后移多少个位置 */

scanf("%d",&m);

move(number,n,m);/* 调用move 函数 */

printf("Now, they are: \n");

for(i=0;i

printf("%d",number[i]);

}

void move(int array[20],int n,int m)/* 循环后移-次的函数 */

{ int*p,array_end;

array_end=*(array+n-1);

for(p=array+n-1;p>array;p--)

*p=*(p-1);

*array=array_end;

m--;

if(m>0) move(array,n,m);/* 递归调用,当循环次数m减至0 */

/* 时,停止调用 */

}

运行结果:

How many numbers? 8↙

Input 8 numbers:

1243656782711↙

How many place you want to move? 4↙

Now, they are:

8271112436567

10.5 有n个人围成一圈,顺序排号。从第一个人开始报数(从l到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

解:

:(xt10-5.c)

#include

main()

{ int i,k,m,n,num[50],*p;

printf("Input number of person: n=");

scanf("%d",&n);

p=num;

for(i=0;i

*(p+i)=i+1;/*以l至n为序给每个人编号*/

i=0;/* i为每次循环时的计数变量*/

k=0;/* k为按1、2、3报数时的计数变量 */

m=0;/* m为退出人数 */

while(m/* 当退出人数比n-1少时(即未退出人数大于1时)执行循环体 */

{ if(*(p+i)!=0) k++;

if(k==3)/* 对退出的人的编号置为0 */

{ *(p+i)=0;

k=0;

m++;

}

i++;

if(i==n) i=0;/* 报数到尾后, i恢复为0 */

}

while(*p==0) p++;

printf("The last one is NO.%d\n",*p);

}

运行结果:

Input number of person: n=8↙

The last one is NO.7

''

10.6 写一个函数,求一个字符串的长度。在main函数中输入字符串,并输出其长度。

解:程序如下:(xt10-6.c)

#include

main()

{ intlen;

char *str[20];

int length(char *p);

printf("Input string: ");

scanf("%s",str);

len=length(str);

printf("The length of string is %d.\n",len);

}

int length(char *p)/* 求字符中长度函数 */

{ intn;

n=0;

while(*p!='\0')

{ n++;

p++;

}

return(n);

}

运行结果:

Input string: China↙

The length of string is 5.

10.7 有一字符串,包含n个字符。写一个函数,将此字符串中从第m个字符开始的全部字符复制成为另一个字符串。

解:程序如下:(xt10-7.c)

#include

#include

main()

{ intm;

char *str1[20],*str2[20];

void copystr(char *p1,char *p2,int m);

printf("Input string: ");

gets(str1);

printf("Which character that begin to copy? ");

scanf("%d",&m);

if(strlen(str1)

printf("Input error!");

else

{ copystr(str1,str2,m);

printf("resut: %s\n",str2);

}

}

void copystr(char *p1,char *p2,int m)/* 字符串部分复制函数 */

{ intn;

n=0;

while(n

{ n++;

p1++;

}

while(*p1!='\0')

{ *p2=*p1;

p1++;

p2++;

}

*p2='\0';

}

运行结果:

Input string: reading-room↙

Which character that begin to copy? 9↙

result: room

10.8 输入一行文字,找出其中大写字母、小写字母、空格、数字及其他字符各有多少。

解:程序如下:(xt10-8.c)

#include

main()

{ intupper=0,lower=0,digit=0,space=0,other=0,i=0;

char *p,s[80];

printf("Input string: ");

while((s[i]=getchar())!='\n') i++;

p=&s[0];

while(*p!='\n')

{ if(('A'<=*p)&&(*p<='Z')) upper++;

else if(('a'<=*p)&&(*p<='z')) lower++;

else if(*p==' ')space++;

else if(('0'<=*p)&&(*p<='9')) digit++;

elseother++;

p++;

}

printf("upperer case:%d\n",upper);

printf("lowerer case:%d\n",lower);

printf("digit:%d\n",digit);

printf("space:%d\n",space);

printf("other:%d\n",other);

}

运行结果:

Input string: Today is 2000/1/1↙

upperer case:1

lowerer case:6

digit:6

space:2

other:2

10.9 写一个函数,将一个3×3的矩阵转置。

解:程序如下:(xt10-9.c)

#include

main()

{ inta[3][3],*p,i;

void move(int *pointer);

printf("Input matrix: \n");

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

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

p=&a[0][0];

move(p);

printf("Now,matrix: \n");

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

printf("%d %d %d\n",a[i][0],a[i][1],a[i][2]);

}

voidmove(int *pointer)

{ inti,j,t;

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

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

{ t=*(pointer+3*i+j);

*(pointer+3*i+j)=*(pointer+3*j+i);

*(pointer+3*j+i)=t;

}

}

运行结果:

Input matrix:

l 2 3↙

4 5 6↙

7 8 9↙

Now,matrix:

1 4 7

2 5 8

3 6 9

l0.l0 将一个5×5的矩阵中最大的元素放在中心,4个角分别放4个最小的元素(按从

左到右、从上到下的顺序 ,依次从小到大存放),写一个函数实现之,并用main数调用。

解:程序如下:(xt10-10.c)

#include

main()

{ inta[5][5],*p,i,j;

void change(int *p);

printf("Input matrix:\n");

for(i=0;i<5;i++)/*输入矩阵*/

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

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

p=&a[0][0];/*使p指向0行0列元素*/

change(p);/*调用函数, 实现交换*/

printf("Now, matrix: \n");

for(i=0;i<5;i++)/*输出已交换的矩阵*/

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

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

printf("\n");

}

}

void change(int *p)/*交换函数*/

{ inti,j,temp;

int *pmax,*pmin;

pmax=p;

pmin=p;

for(i=0;i<5;i++)/*找最大值和最小值的地址,并赋给pmax,pmin*/

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

{ if(*pmax

if(*pmin>*(p+5*i+j)) pmin=p+5*i+j;

}

temp=*(p+12);/*将最大值换给中心元素*/

*(p+12)=*pmax;

*pmax=temp;

temp=*p;/*将最小值换给左上角元素*/

*p=*pmin;

*pmin=temp;

pmin=p+1;

for(i=0;i<5;i++)/*找第二最小值的地址赋给pmin*/

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

if(((p+5*i+j)!=p)&&(*pmin>*(p+5*i+j)))pmin=p+5*i+j;

temp=*pmin;/*将第二最小值换给右上角元素*/

*pmin=*(p+4);

*(p+4)=temp;

pmin=p+1;

for(i=0;i<5;i++)/*找第三最小值的地址赋给pmin*/

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

if(((p+5*i+j)!=(p+4))&&((p+5*i+j)!=p)&&(*pmin>*(p+5*i+j)))

pmin=p+5*i+j;/*将第三最小值换给左下角元素*/

temp=*pmin;

*pmin=*(p+20);

*(p+20)=temp;

pmin=p+1;

for(i=0;i<5;i++)/*找第四最小值的地址赋给pmin*/

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

if(((p+5*i+j)!=p)&&((p+5*i+j)!=(p+4))&&((p+5*i+j)!=

(p+20))&&(*pmin>*(p+5*i+j)))pmin=p+5*i+j;

temp=*pmin;/*将第四最小值换给右下角元素*/

*pmin=*(p+24);

*(p+24)=temp;

}

运行结果:

Input matrix:

35 34 33 32 31↙

3O 29 28 27 26↙

25 24 23 22 21↙

15 14 13 12 ll↙

Now, matrix:

11 34 33 32 12

30 29 28 27 26

25 24 35 22 21

20 l9 18 17 16

13 23 15 31 14

10.11在主函数中输入10个等长的字符串。用另一个函数对它们排序,然后在主函数输出这10个已排好的字符串。

解:程序如下:(xt10-11.c)

#include

#include

main()

{ voidsort(char s[10][6]);

int i;

char str[10][6];

printf("Input 10 strings:\n");

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

scanf("%s",str[i]);

sort(str);

printf("Now, the sequence is:\n");

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

printf("%s\n",str[i]);

}

voidsort(char s[10][6])

{ inti,j;

char *p,temp[10];

p=temp;

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

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

if(strcmp(s[j],s[j+1])>0 )

{ strcpy(p,s[j]);

strcpy(s[j],s[+j+1]);

strcpy(s[j+1],p);

}

}

运行结果:

Input 10 strings:

China↙

Japan↙

Korea↙

Egypt↙

Nepal↙

Burma↙

Ghana↙

Sudan↙

Italy↙

Libya↙

Now, the sequence is:

Burma

China

Egypt

Ghana

Italy

Japan

Korea

Libya

Nepal

Sudan

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/560968.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

震惊!printf 与scanf 不可告人的秘密

目录 1. printf与scanf2.sqrt函数3.π4.三位数反转5.三整数排序 1. printf与scanf #include<stdio.h> int main() {printf("%lf\n",8.0/5.0);printf("%lf\n",8/5.0);printf("%lf\n",8/5);printf("%d\n",8.0/5.0);printf(&quo…

华为防火墙查看日志命令_华为防火墙异常日志,请高手进来查看,跪谢

华为Sec-Path500防火墙&#xff0c;用控制线登进去之后&#xff0c;一直在显示如下日志&#xff0c;根本无法进行命令的输入操作&#xff1a;%Jul 6 11:12:39:486 2016 FW1.BJ SEC/4/ATCKDF:atckType(1016)(0)IP-spoofing;rcvIfName(1023)GigabitEthernet1/0;srcIPAddr(1017)1…

2014年二级c语言,2014年计算机二级考试C语言选择题

2014年计算机二级考试C语言选择题{ char x0xFFFF;printf("%d\n"&#xff0c;x--);}A.-32767B.FFFEC.1D.3276822.下面的函数调用语句中func函数的实参个数是( )。func((f2v1&#xff0c;v2)&#xff0c;(v3&#xff0c;v4&#xff0c;v5)&#xff0c;(v6&#xff0c;m…

算法竞赛入门经典 第二章总结

1.例题aabb 输出 所有形如aabb的4位完全平方数 分析&#xff1a; 方案1.判断a*1100b*11是不是完全平方数&#xff08;枚举a和b&#xff09; 方案2.判断4位完全平方数是否满足aabb形式(枚举1000到9999中的完全平方数&#xff09; 代码&#xff1a; #include<stdio.h&g…

mfc tabcontrol 修改白色背景_初级会计报名准备工作如何使用美图秀秀PC版修改照片尺寸、格式、大小...

点击上方蓝字关注我们证件照是我们生活中常用的东西&#xff0c;大学考证需要证件照&#xff0c;制作简历也需要用到证件照&#xff0c;工作有时也需要用到&#xff0c;然而最让我们头疼的是每次报名证件照的要求都不一样&#xff0c;其中底色和尺寸是经常需要修改的&#xff0…

东莞理工c语言作业,东莞理工学院 c语言复习题

第一部分1. C语言的主要特点有哪些?(多选)A.简洁、紧凑&#xff0c;使用方便、灵活&#xff0c;易于学习和应用。B.&#xff23;语言是面向结构化程序设计的语言。C.&#xff23;语言允许直接对位、字节和地址进行操作。D.数据类型丰富。E.&#xff23;语言生成的目标代码质量…

算法竞赛入门经典 第五章总结1

例题1&#xff1a; 输入多行数据&#xff0c;每行包含若干个以空格隔开的整数&#xff0c;输出每行中所有整数之和 #include<iostream> #include<string> #include<sstream> using namespace std; int main(){string line;while(getline(cin,line)){int su…

python 3维正态分布图_三维正态分布图

听起来你要找的是一个Multivariate Normal Distribution。这在scipy中实现为scipy.stats.multivariate_normal。重要的是要记住&#xff0c;你要传递一个协方差矩阵给函数。所以为了简单起见&#xff0c;将非对角元素保留为零&#xff1a;[X variance , 0 ][ 0 ,Y Variance]下面…

16位浮点 c语言,C语言中的16位浮点乘法

我正在开发一个小项目&#xff0c;我需要浮点乘法和16位浮点数(半精度)。不幸的是&#xff0c;我遇到了算法的一些问题&#xff1a;示例输出1 * 5 52 * 5 103 * 5 14.54 * 5 205 * 5 24.5100 * 4 100100 * 5 482源代码const int bits 16;const int exponent_length 5;…

pitr 原理_PostgreSQL基于时间点恢复(PITR)

OS 环境&#xff1a;CentOS 6.2数据库 &#xff1a;PostgreSQL 9.1.3pg_home/home/postgres/pg_data/database/pgdata/一、前期工作既要恢复&#xff0c;肯定是需要一个备份基础的&#xff0c;否则再怎么的巧妇也难为无米之炊。1.修改数据库参数&#xff0c;修改postgresql.con…

c++类和对象初步

程序设计与算法&#xff08;三&#xff09;C面向对象程序设计-郭炜 第二周 总结整理&#xff1a; 目录&#xff1a; 1.类成员的可访问范围2.成员函数的 重载及参数缺省3.构造函数 (constructor)4.复制构造函数 copy constructor5.类型转换构造函数6.析构函数 destructors 1…

imx6ull用video4linux,CB140(imx6ull)使用Openwrt系统

主机平台&#xff1a; UBUNTU14.04硬件平台&#xff1a;明远智睿MY-IMX6-EK140P (其他平台也是)编译器: gcc-linaro-5.3-2016.02-x86_64_arm-linux-gnueabihf.tar.xz内核版本 linux-4.1.15文件系统&#xff1a; openwrt_last_rootfs.tar.bz2 (附件有)简介&#xff1a;…

分步表单_表单设计-掌握表单设计方法(表单体验篇)

全篇阅读大概需要15min&#xff0c;对表单设计不熟悉的同学看完后肯定会有不少的收获~~~说到表单其实在生活中可以接触到各种各样的表单&#xff0c;比如&#xff1a;驾照申请表、体检表、银行开户需要填写的表等等&#xff0c;这些都是表单&#xff0c;主要目的就是让用户填写…

类和对象提高

程序设计与算法&#xff08;三&#xff09;C面向对象程序设计-郭炜 第三周 总结整理&#xff1a; 目录&#xff1a; 1.this指针2.静态成员3.成员对象和封闭类4.友元 &#xff08;friends)5.常量成员函数 1.this指针 C程序到C程序的翻译 class CCar { public: int price;…

4)lsof linux命令,***Linux命令实时监测系统(top,htop,iotop,lsof,tcpdump,netstat,vmstat,iostat)...

摘要&#xff1a;本文总结了8个非常实用的Linux命令行性能监测工具&#xff0c;这些命令支持所有的Linux系统&#xff0c;不仅可以用于监控系统&#xff0c;还可以发现导致性能问题的原因所在。对每个系统/网络管理员来说&#xff0c;每天监测Linux系统性能是一项非常艰巨的任务…

算法竞赛入门经典 第七章 总结

目录&#xff1a; 7.1 简单枚举7.2 枚举排列7.3 子集生成 7.1 简单枚举 例题7-1 除法&#xff08;Division, UVa 725&#xff09; 输入正整数n&#xff0c;按从小到大的顺序输出所有形如abcde/fghij n的表达式&#xff0c;其中a&#xff5e;j恰好 为数字0&#xff5e…

bootstraptable 列隐藏_bootstrap中table如何隐藏列?

Bootstrap如何隐藏table中的某一列&#xff1f;下面本篇文章给大家介绍一下。有一定的参考价值&#xff0c;有需要的朋友可以参考一下&#xff0c;希望对大家有所帮助。Bootstrap隐藏table中的某一列1、利用bootstrapTable来设置要隐藏和显示的列$(function () {//初始化tableL…

华为android强刷系统下载地址,华为强刷救砖卡刷包合集下载(一)共707GB

(High Level Repair Center is forbidden)Berlin-AL10AC00B381_Android7.0_EMUI5.0_05014NVD.zip(High Level Repair Center is forbidden)GRA-CL00_C92B370_Android6.0_EMUI4.0.2_05012QKC.zipMLA-AL10C00B360_Android7.0_EMUI5.0.1_05014DHN.zipMLA-UL00_C17B170_China_联通…

线性表总结

线性表及其实现多项式的表示什么是线性表线性表的抽象数据类型描述线性表的顺序存储实现线性表的链式存储实现 线性表及其实现 多项式的表示 [例] 一元多项式及其运算 一元多项式 &#xff1a; 主要运算&#xff1a;多项式相加、相减、相乘等 【分析】如何表示多项式?…

md 生成目录 码云_搭建简易博客方案

现在大家都喜欢用markdown来写技术博客&#xff0c;这篇文章将阐述搭建支持markdown的简易博客方法。我的写作需求通过阅读本文&#xff0c;您将学会搭建满足以下条件的博客&#xff1a;博客只用书写markdown文件能支持版本控制免费&#xff0c;不需要租服务器或主机编写、部署…