鱼C论坛

 找回密码
 立即注册
查看: 1443|回复: 1

[已解决]C语言作业

[复制链接]
发表于 2020-11-4 11:39:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题描述】

从键盘输入一个正整数(无符号长整型),将该正整数中的每位数字重新排列,分别组成一个最大数和一个最小数并依次输出,两数间用空格分隔。

【输入形式】

从键盘输入一个无符号长整型整数。

【输出形式】

输出最大数和最小数,两数间用空格分隔,最小数左端的0不应输出。

【样例输入】

47091

【样例输出】

97410 1479
最佳答案
2020-11-4 13:01:33
#include <stdio.h>

void func(unsigned long long * min , unsigned long long * max , unsigned long long m)
{
        char b[64] = {0} , c                                   ;
        int d , j , k , n                                      ;
        for(d = 0 ; m ; d ++ , m /= 10) b[d] = (char) (m % 10) ;
        for(j = 1 ; j < d ; j ++) {
                for(k = j ; k && b[k] < b[k - 1] ; k --) {
                        c = b[k]                               ;
                        b[k] = b[k - 1]                        ;
                        b[k - 1] = c                           ;
                }
        }
        for(* max = 0 , * min = 0 , k = 0 ; k < d ; k ++) {
                * max = * max * 10 + b[d - 1 - k]              ;
                * min = * min * 10 + b[k]                      ;
        }
}

main(void)
{
        unsigned long long min , max , m    ;
        scanf("%I64u" , & m)                ;
        func(& min , & max , m)             ;
        printf("%I64u %I64u\n" , max , min) ;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-4 13:01:33 | 显示全部楼层    本楼为最佳答案   
#include <stdio.h>

void func(unsigned long long * min , unsigned long long * max , unsigned long long m)
{
        char b[64] = {0} , c                                   ;
        int d , j , k , n                                      ;
        for(d = 0 ; m ; d ++ , m /= 10) b[d] = (char) (m % 10) ;
        for(j = 1 ; j < d ; j ++) {
                for(k = j ; k && b[k] < b[k - 1] ; k --) {
                        c = b[k]                               ;
                        b[k] = b[k - 1]                        ;
                        b[k - 1] = c                           ;
                }
        }
        for(* max = 0 , * min = 0 , k = 0 ; k < d ; k ++) {
                * max = * max * 10 + b[d - 1 - k]              ;
                * min = * min * 10 + b[k]                      ;
        }
}

main(void)
{
        unsigned long long min , max , m    ;
        scanf("%I64u" , & m)                ;
        func(& min , & max , m)             ;
        printf("%I64u %I64u\n" , max , min) ;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-12 17:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表