基于visual Studio2013解决C语言竞赛题之0702函数设计

原创 2013年12月06日 11:28:08





题目


解决代码及点评

/*
输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。
写三个函数:①输入10个数;②进行处理;③输出10个数。
*/
#include<stdio.h>
#include <stdlib.h>

int a[10];
void f721(int *a)//输入10个数
{	
	for (int i=0;i<10;i++)
	{
		a[i]=rand()%100;
		printf("%d\t",a[i]);
	}
}

void f722(int *pmax,int *pmin,int *a,int *p1,int *p2)//进行处理
{

	for (int i=0;i<10;i++)
	{
		if (*pmin>a[i])
		{
			*pmin=a[i];
			*p1=i;
		}
		if (*pmax<a[i])
		{
			*pmax=a[i];
			*p2=i;
		}	
	}
	//最小数和第一个数交换
	a[0]=a[0]+a[*p1];
	a[*p1]=a[0]-a[*p1];
	a[0]=a[0]-a[*p1];

	//最大数和最后一个数交换
	a[9]=a[9]+a[*p2];
	a[*p2]=a[9]-a[*p2];
	a[9]=a[9]-a[*p2];

}

void f723(int *a)
{
	for (int i=0;i<10;i++)//输出新的数
	{
		printf("%d\t",a[i]);
	}
}


void main()
{

	f721(a);

	int *pmax=(int *)malloc(sizeof(int)),*pmin=(int *)malloc(sizeof(int));
	*pmin=a[0];
	*pmax=a[0];

	int kmin=0,kmax=0;//记录最大数和最小数de下标

	int *p1=&kmin,*p2=&kmax;

	f722(pmax,pmin,a,p1,p2);

	printf("kmin=%d,kmax=%d\n",kmin,kmax);

	f723(a);

	free(pmax);
	free(pmin);

	system("pause");
}



代码编译以及运行

由于资源上传太多,资源频道经常被锁定无法上传资源,同学们可以打开VS2013自己创建工程,步骤如下:

1)新建工程

2)选择工程

3)创建完工程如下图:

4)增加文件,右键点击项目

5)在弹出菜单里做以下选择

6)添加文件

7)拷贝代码与运行


程序运行结果





版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

基于visual Studio2013解决C语言竞赛题之0608水仙花函数

题目解决代码及点评/* 功能:写一函数判断某数是否“水仙花数”,所谓“水仙花数”是指一个三位数, 其各位数字立方和等于该数本身。 */ #include #include int flo...

基于visual Studio2013解决C语言竞赛题之0602最大值函数

题目解决代码及点评#include #include /* 编写一函数求三个整数的最大值。 */ void f62(int a ,int b,int c) { int temp=a; if (...

基于visual Studio2013解决C语言竞赛题之0407最大值最小值

题目解决代码及点评/************************************************************************/ /* 7. 任意十个数,打印出...

基于visual Studio2013解决C语言竞赛题之1054抽牌游戏

题目解决代码及点评/************************************************************************/ /* 54. 有N张牌,计算机...

基于visual Studio2013解决C语言竞赛题之0803报数

题目解决代码及点评/* 功能:13个人围成一圈,从第一个人开始顺序报号1、2、3。 凡报到“3”者退出圈子。找出最后留在圈子里的人原来的序号。 */ #include #inclu...

基于visual Studio2013解决C语言竞赛题之0201温度转换

题目解决代码及点评#include #include void main() { float f; float c; float k; printf("please input the f...

基于visual Studio2013解决C语言竞赛题之1067间隔排序

题目解决代码及点评/* 功能:间隔元素排序。用随机函数产生25个[25,75]之间的整数, 把它送到一维数组M中。 要求对M[I],M[I+J],M[I+2*J],…这些元素按从小到大的顺...

基于visual Studio2013解决C语言竞赛题之1065二维排序

题目解决代码及点评/* 功能:二维数组排序。设有4×5的数组M,通过排序使 M[1][1]≤M[1][2]≤...≤M[1][5]≤M[2][1]≤M[2][2]≤...≤M[2][5]≤...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:基于visual Studio2013解决C语言竞赛题之0702函数设计
举报原因:
原因补充:

(最多只允许输入30个字)