- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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(
您可能关注的文档
最近下载
- 心理健康主题班会教育ppt模板.pptx
- 【国家标准】GBT 2565-2014 煤的可磨性指数测定方法 哈德格罗夫法.pdf
- 新型雾化硅油的制备及其性能表征.pdf
- 2024-2025学年人部编版五年级语文第一学期期末质量检测题及答案(共4套).pdf VIP
- 危化企业开工第一课.pptx VIP
- 2023年和顺县社区工作者招聘笔试试题及答案解析.docx
- 2024年山西省煤矿安全管理人员培训考试题库附答案(通用版).docx
- 保健食品生产企业《纯化水系统设计确认》示例.docx
- 财经应用文写作李彦 潘朝中财经公务文书参考答案.pdf VIP
- 煤矿企业人力资源管理问题及对策.docx VIP
文档评论(0)