• 输入10个整数,将其中最小的数与第一个数对换, 把最大的数与最后一个数对换


    输入10个整数,将其中最小的数与第一个数对换, 把最大的数与最后一个数对换。

    写3个函数:

    ①输人10个数;

    ②进行处理;

    ③输出10个数。

    解题思路: 在进行数值逐个比较的同时找到最小值的空间地址以及最大值的空间地址,使用这两个空间中的数据最终与第一和最后数据进行对换即可。

    答案:

    #include <stdio.h>
    
    void input(int *arry, int len)
    {
    	for (int i = 0; i < len; i++) {
    		scanf_s("%d", &arry[i]);
    	}
    }
    void print(int *arry, int len)
    {
    	for (int i = 0; i < len; i++) {
    		printf("%d ", arry[i]);
    	}
    	printf("
    ");
    }
    void handle(int *arry, int len)
    {
    	int max_num = arry[0], min_num = arry[0];
    	int *p_max = NULL, *p_min = NULL;
    	for (int i = 1; i < len; i++) {
    		if (min_num > arry[i]) {//逐个比对后找出最小值
    			min_num = arry[i];
    			p_min = &arry[i];	//逐个比对后找到最小值的空间地址
    		}
    		if (max_num < arry[i]) {//逐个比对后找出最大值
    			max_num = arry[i];
    			p_max = &arry[i];   //逐个比对后找到最大值的空间地址
    		}
    	}
    	int tmp;
    	tmp = *p_min; *p_min = arry[0]; arry[0] = tmp;  //最小值与第一个数据交换
    	tmp = *p_max; *p_max = arry[len - 1]; arry[len - 1] = tmp;//最大值与最后一个数据交换
    }
    int main()
    {
    	int arry[10];
    	printf("Please enter ten nums:");
    	input(arry, 10);
    	handle(arry, 10);
    	print(arry, 10);
    	system("pause");
    	return 0;
    }
    

    输入10个整数,将其中最小的数与第一个数对换, 把最大的数与最后一个数对换

  • 相关阅读:
    BZOJ2530 : [Poi2011]Party
    BZOJ3998 : [TJOI2015]弦论
    BZOJ3941 : [Usaco2015 Feb]Fencing the Herd
    BZOJ3939 : [Usaco2015 Feb]Cow Hopscotch
    搬家啦~
    BZOJ3837 : [Pa2013]Filary
    使用Privoxy做智能代理切换
    放弃iOS4,拥抱iOS5
    让Xcode的 stack trace信息可读
    改进iOS客户端的升级提醒功能
  • 原文地址:https://www.cnblogs.com/weiyidedaan/p/13275334.html
Copyright © 2020-2023  润新知