C语言编程题

代码

#include 
"stdafx.h"
typedef 
int (* pfun)(int a,int b);
int IsNumberEqual(int number) ;
void ntos (int number, int c[]) ;
void  sort (int a[ ],pfun pf  );
int getmaxn(int a[ ]);
int getminn(int b[ ]);

int asc(int a,int b) {return (a>b?1:0);}
int desc(int a,int b){return (a<b?1:0);}

int main(int argc, char* argv[])
{
    
int num=0;
    printf(
"Please enter a number:");
    scanf(
"%d",&num);        
    
//IsNumberEqual调用时若数不为4位,或有危险,故放最后,短路返回
    while( num<1000 || num>9999 || IsNumberEqual(num) ){
        printf(
"invalid number :%d,try again:\n",num);
        scanf(
"%d",&num);
    }    
    
int arr[4],max,min;
    
do{
        ntos(num,arr);
        max
=getmaxn(arr);
        printf(
"max=%d,",max);
        min
=getminn(arr);
        printf(
"min=%d\n",min);
        num
=max-min;
    }
while(num!=6174);
    
    printf(
"\n max(%d)-min(%d)=%d \n",max,min,max-min);
    printf(
"\ndone");
    
return 0;
}
//用函数 int IsNumberEqual(int number) 检查输入的整数number各数码是否互不相等,
//有相等返回值为1否则为0;
int IsNumberEqual(int number) 
{
    
int a[4]={0,};
    ntos(number,a);
    
int iRes=0;
    
for(int i=0;i<4;++i){
        
for(int j=i+1;j<4;++j){
            
if( a[i]==a[j] ){
                iRes
=1;
                
break;
            }            
        }
        
if(iRes==1)break;
    }
    
return iRes;
}

//用函数(void ntos (int number, int c[]) )把四位数整数number各位数码分别存入数组c
void ntos (int number, int c[]) 
{
    
for(int i=0;number>0;++i){
        c[i]
=number%10;
        number
/=10;
    }
}
//用函数( void  sort (int a[ ] )对4个元素的数组a排序(升序或降序都可以);
void  sort (int a[ ],pfun pf  )
{
    
//选择法
    for(int i=0;i<4;++i){
        
for(int j=i+1;j<4;++j){
            
if( pf(a[i],a[j]) ){
                
int t=a[i];
                a[i]
=a[j];
                a[j]
=t;
            }
        }
    }
}

//返回值为最大值
int getmaxn(int a[ ])
{
    
int sum=0,pow=1;
    sort(a,desc);
    
for(int i=3;i>=0;--i,pow*=10){
        sum
+=a[i]*pow;
    }
    
return sum;
}
//返回值为最小值 
int getminn(int a[ ])  
{
    
int sum=0,pow=1;
    sort(a,asc);
    
for(int i=3;i>=0;--i,pow*=10){
        sum
+=a[i]*pow;
    }
    
return sum;
}

 

posted @ 2010-01-06 08:50  庚武  Views(196)  Comments(0Edit  收藏  举报