鱼C论坛

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

[已解决]C语言作业

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

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

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

x
【问题描述】

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

【输入形式】

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

【输出形式】

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

【样例输入】

47091

【样例输出】

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

  2. void func(unsigned long long * min , unsigned long long * max , unsigned long long m)
  3. {
  4.         char b[64] = {0} , c                                   ;
  5.         int d , j , k , n                                      ;
  6.         for(d = 0 ; m ; d ++ , m /= 10) b[d] = (char) (m % 10) ;
  7.         for(j = 1 ; j < d ; j ++) {
  8.                 for(k = j ; k && b[k] < b[k - 1] ; k --) {
  9.                         c = b[k]                               ;
  10.                         b[k] = b[k - 1]                        ;
  11.                         b[k - 1] = c                           ;
  12.                 }
  13.         }
  14.         for(* max = 0 , * min = 0 , k = 0 ; k < d ; k ++) {
  15.                 * max = * max * 10 + b[d - 1 - k]              ;
  16.                 * min = * min * 10 + b[k]                      ;
  17.         }
  18. }

  19. main(void)
  20. {
  21.         unsigned long long min , max , m    ;
  22.         scanf("%I64u" , & m)                ;
  23.         func(& min , & max , m)             ;
  24.         printf("%I64u %I64u\n" , max , min) ;
  25. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

  2. void func(unsigned long long * min , unsigned long long * max , unsigned long long m)
  3. {
  4.         char b[64] = {0} , c                                   ;
  5.         int d , j , k , n                                      ;
  6.         for(d = 0 ; m ; d ++ , m /= 10) b[d] = (char) (m % 10) ;
  7.         for(j = 1 ; j < d ; j ++) {
  8.                 for(k = j ; k && b[k] < b[k - 1] ; k --) {
  9.                         c = b[k]                               ;
  10.                         b[k] = b[k - 1]                        ;
  11.                         b[k - 1] = c                           ;
  12.                 }
  13.         }
  14.         for(* max = 0 , * min = 0 , k = 0 ; k < d ; k ++) {
  15.                 * max = * max * 10 + b[d - 1 - k]              ;
  16.                 * min = * min * 10 + b[k]                      ;
  17.         }
  18. }

  19. main(void)
  20. {
  21.         unsigned long long min , max , m    ;
  22.         scanf("%I64u" , & m)                ;
  23.         func(& min , & max , m)             ;
  24.         printf("%I64u %I64u\n" , max , min) ;
  25. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-11 15:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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