编程语言
首页 > 编程语言> > 结构化程序设计:输入一个正整数(不超过5位数),输出由该数的各位能表示的最大数和最小数。

结构化程序设计:输入一个正整数(不超过5位数),输出由该数的各位能表示的最大数和最小数。

作者:互联网

结构化程序设计:输入一个正整数(不超过5位数),输出由该数的各位能表示的最大数和最小数。

思路

  首先将正整数分拆得到各个位上的数字,对这些数字按从小到大排序,再考虑按照乘权求和的方式转换成相应的整数既可得到最大最小结果

代码

#include <stdio.h>
#include <string.h>
void split(int x,int a[],int *count);
void sortA(int a[],int count);
void getMaxMin(int a[],int count,int *max,int *min);
int main()
{
    int x,a[5],count=0,max,min;
    scanf("%d",&x);
    split(x,a,&count);//分离x各位数到数组a中,count利用指针传递给函数,使它能记录x的位数
    sortA(a,count);//对数组a进行排序
    getMaxMin(a,count,&max,&min);//根据乘权求和算法,对已排好序的数组a分别从大到小和从小到大计算最大最小值
    printf("max=%d,min=%d",max,min);//输出结果
}

void split(int x,int a[],int *count)
{
	 /*x是你输入的值,a是将x所有位分离出来存放的数组,指针count指向main函数的count变量,用于记录x的位数*/
    while(x)
    {
        a[*count]=x%10;
        x/=10;
        (*count)++;
    }
}

void sortA(int a[],int count)
{
	 /*对数组a进行排序,选择排序或冒泡排序均可,count是数组a实际的元素个数,即x的位数*/
    int i,j,k,tmp;
    for(i=0;i<count-1;i++)
    {
        k=i;
        for(j=i+1;j<count;j++)
            if(a[j]<a[k])k=j;
        if(k!=i)tmp=a[i],a[i]=a[k],a[k]=tmp;
    }
}

void getMaxMin(int a[],int count,int *max,int *min)
{
	 /*a是已经排好序的数组,指针max和min分别指向main函数中的max变量和min变量,用于将两个结果带回main函数*/
    int i;
    *max=*min=0;
    for(i=0;i<count;i++)
    {
        *min=*min*10+a[i];
        *max=*max*10+a[count-i-1];
    }
}

分析

  直接写代码十分复杂,所以我们将问题的解决分成三个部分

1.分离x各位数到数组a中

void split(int x,int a[],int *count)
{
	 /*x是你输入的值,a是将x所有位分离出来存放的数组,指针count指向main函数的count变量,用于记录x的位数*/
    while(x)
    {
        a[*count]=x%10;
        x/=10;
        (*count)++;
    }
}

2.对数组a进行排序

void sortA(int a[],int count)
{
	 /*对数组a进行排序,选择排序或冒泡排序均可,count是数组a实际的元素个数,即x的位数*/
    int i,j,k,tmp;
    for(i=0;i<count-1;i++)
    {
        k=i;
        for(j=i+1;j<count;j++)
            if(a[j]<a[k])k=j;
        if(k!=i)tmp=a[i],a[i]=a[k],a[k]=tmp;
    }
}

3.根据乘权求和算法,对已排好序的数组a分别从大到小和从小到大计算最大最小值

void getMaxMin(int a[],int count,int *max,int *min)
{
	 /*a是已经排好序的数组,指针max和min分别指向main函数中的max变量和min变量,用于将两个结果带回main函数*/
    int i;
    *max=*min=0;
    for(i=0;i<count;i++)
    {
        *min=*min*10+a[i];
        *max=*max*10+a[count-i-1];
    }
}

标签:count,最大数,min,int,max,void,结构化程序,数组,该数
来源: https://blog.csdn.net/weixin_50803771/article/details/110847493