| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1266 人关注过本帖, 1 人收藏
标题:把程序得到的几个数按照首数字大小顺序输出
只看楼主 加入收藏
匆匆来过
Rank: 1
来 自:广州
等 级:新手上路
帖 子:26
专家分:9
注 册:2015-12-27
结帖率:50%
收藏(1)
已结贴  问题点数:10 回复次数:5 
把程序得到的几个数按照首数字大小顺序输出
我通过一段代码得出了50000内的阶乘数,至于什么事阶乘数不懂没关系,问题是我得出的数(1 2 145 40585)如何按照字典序即1打头的在前,2打头的在后输出(1 145 2 40585),谁来帮我改下代码?
#include<stdio.h>
int main()
{
    extern int fx(int x);
    int n, a, b, c, d, e, sum;
    for(n = 1; n <= 50000; n++)
    {
        a = n / 10000;
        b = n / 1000 % 10;
        c = n / 100 % 100 % 10;
        d = n / 10 % 1000 % 100 % 10;
        e = n % 10000 % 1000 % 100 % 10;
        if( n < 10 )
            sum=fx(e);
        else if( n < 100 && n >= 10 )
            sum=fx(d)+fx(e);
        else if( n >= 100 && n < 1000 )
            sum=fx(c)+fx(d)+fx(e);
        else if( n >= 1000 && n <10000 )
            sum=fx(b)+fx(c)+fx(d)+fx(e);
        if( n >= 10000 )
            sum=fx(a)+fx(b)+fx(c)+fx(d)+fx(e);
        if( sum == n )
        {
            //printf("%d->",n);
            //printf("%d,%d,%d,%d,%d  ",a,b,c,d,e);
            //printf("sum=%d\n",sum);
            printf("%d ",n);
        }
    }
    return 0;
}

int fx(int x)
{
    int i, sum=1;
    if(x==0)
        return 1;
    else
    {
        for(i=1;i<=x;i++)
            sum=i*sum;
        return sum;
    }
}
搜索更多相关主题的帖子: include 如何 
2016-03-26 14:13
匆匆来过
Rank: 1
来 自:广州
等 级:新手上路
帖 子:26
专家分:9
注 册:2015-12-27
收藏
得分:0 
图片附件: 游客没有浏览图片的权限,请 登录注册

努力打代码
2016-03-26 14:14
匆匆来过
Rank: 1
来 自:广州
等 级:新手上路
帖 子:26
专家分:9
注 册:2015-12-27
收藏
得分:0 
图片附件: 游客没有浏览图片的权限,请 登录注册

努力打代码
2016-03-26 14:15
wmf2014
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:216
帖 子:2039
专家分:11273
注 册:2014-12-6
收藏
得分:5 
简单办法是全部补成相同位数的数,再排序,再还原显示即可。
1      2      145     40585
100006 200006 145003  405851
排序
100006 145003 200006  405851
还原
1      125    2       40585

能编个毛线衣吗?
2016-03-26 14:28
匆匆来过
Rank: 1
来 自:广州
等 级:新手上路
帖 子:26
专家分:9
注 册:2015-12-27
收藏
得分:0 
回复 4楼 wmf2014
有难度,而且在程序中你不知道结果是哪些数,有几位

努力打代码
2016-03-26 19:19
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:5 
用qsort函数,比较子则如四楼所言,转化为字符串后直接strcmp比较。
数字转化为字符串最简单(不高效)的就是大家常用的sprintf
2016-03-26 20:28
快速回复:把程序得到的几个数按照首数字大小顺序输出
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.329187 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved