常见C语言程序.docx

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

输入两个数(iData1,iData2),用指针实现输入的数据从大到小输出,要求从大到小排序在函数中实现,函数形参为指针变量。

#includestdio.hvoidswap(int *a,int *b);voidmain()

{

intiData1,iData2;int*p1,*p2;

printf(请输入两个整数(用逗号隔开):\n);scanf(%d,%d,iData1,iData2);p1=iData1;

p2=iData2;if(iData1iData2)

{

}

else

{

printf(交换前:%d,%d\n,*p1,*p2);

swap(iData1,iData2);printf(swap中:%d,%d\n,*p1,*p2);printf(交换后:%d,%d\n,*p1,*p2);

printf(交换前:%d,%d\n,*p1,*p2);printf(swap中:%d,%d\n,*p1,*p2);printf(交换后:%d,%d\n,*p1,*p2);

}

}

voidswap(int *a,int *b)

{

intc;c=*a;

*a=*b;

*b=c;

}

将一个数插入到按升序排序的数列中,新数列仍然有序,用指针实现。#includestdio.h

#includestring.h#defineN10voidmain()

{

inta[N],i,k,t;int*p=a[8];

printf(请输入9个数:);for(i=0;iN-1;i++)

{

scanf(%d,a+i);

}

printf(请输入1个数:);

scanf(%d,a[9]);

for(i=9;i=1;i--)

{

if(*pa[i])

{

}

p--;

}

t=*p;

*p=a[i];

a[i]=t;

for(i=0;iN;i++)

{

printf(%d,a[i]);

}

}

编写一段程序,输入一个3×4的整型矩阵,输出矩阵中的最大值及其下标。

随机存入n个数据存入数组,通过指针参数传递将数组中的最大元素与第一个元素交换,最小元素与最后一个元素交换。

#includestdio.h#defineN100

voidswap(int *a,int *b)

{

intc;c=*a;

*a=*b;

*b=c;

}

voidmain()

{

inti,n;inta[N],*p,*pmax,*pmin,*first,*last;printf(共有几个数(1~100)?);

scanf(%d,n);

printf(它们是:);for(p=a;pa+n;p++)

{

scanf(%d,p);

}

pmax=a;for(p=a;pa+n;p++)

{

if(*p*pmax)

{

pmax=p;

}

}

pmin=a;for(p=a;pa+n;p++)

{

if(*p*pmin)

{

pmin=p;

}

}

printf(数组为:);for(i=0;in;i++)

{

printf(%d,a[i]);

}

printf(\n);

printf(最大数是%d\n,*pmax);printf(最小数是%d\n,*pmin);first=a;

last=a+n-1;swap(first,pmax);swap(last,pmin);

printf(最大元素与第一个元素交换,最小元素与最后一个元素交换为:\n);for(i=0;in;i++)

printf(%d,a[i]);

}

通过指针参数传递,计算自然数n的阶乘。

以下程序将数组a中的数据按逆序存放#includestdio.h

#defineM8voidmain()

{

inta[M],i,j,t;for(i=0;iM;i++)

scanf(%d,a+i);

i=0;

j=M-1;

while(ij)

{

t=*(a+i);

*(a+i)=*(a+j);

*(a+j)=t;i++;

j--;

}

for(i=0;iM;i++)printf(%3d,*(a+i));

}

以下程序的功能是求二维数组a中的最大值与二维数组b中的最大值之差

#includestdio.h#includestring.hfloatfindmax(float*x,intm,intn)

{

inti,j;floatmax=*x;for(i=0;im;i++)for(j=0;jn;j++)

if(*(x+i*m+j)max)

{

max=*(x+i*m+j);

}

returnmax;

}

voidmain()

{

floata[3][3],b[3][2];inti,j;

for(i=0;i3;i++)for(

文档评论(0)

hao187 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体武汉豪锦宏商务信息咨询服务有限公司
IP属地上海
统一社会信用代码/组织机构代码
91420100MA4F3KHG8Q

1亿VIP精品文档

相关文档