| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 502 人关注过本帖
标题:请教一下,这个怎样做
只看楼主 加入收藏
Tchong
Rank: 1
等 级:新手上路
帖 子:117
专家分:0
注 册:2008-10-17
结帖率:100%
收藏
 问题点数:0 回复次数:4 
请教一下,这个怎样做
先输入任意一个数,然后输出一个比这个数大的最小翻转数,例如5可以变成2,6可以变成9.
请问这个程序应该怎样编,要用c语言编,应该有人会吧
搜索更多相关主题的帖子: c语言 
2008-11-07 00:17
wangzhou624
Rank: 1
来 自:成都
等 级:新手上路
帖 子:2
专家分:0
注 册:2008-11-7
收藏
得分:0 
不懂你的意思,为什么5就变成2,6又变成9,说清楚点
2008-11-07 08:54
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
翻转数该不会是把数给倒过来吧

倚天照海花无数,流水高山心自知。
2008-11-07 09:14
广陵绝唱
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:29
帖 子:3607
专家分:1709
注 册:2008-2-15
收藏
得分:0 
程序代码:
/*------------------------------------------------------------------------------

        先输入任意一个数,然后输出一个比这个数大的最小翻转数,例如5可以变成2,
    6可以变成9.

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

        好象看过一个题目:一个人两只手各拿着一块电子记分牌,但他很糊涂,他不记得
    现在的分数应该是多少了。由于电子记分牌有些数字翻转、颠倒后又成为了一个新的数
    字,所以他就把它们翻来翻去,把现在的分数定为大于手中现在分数的最小的数。

        由于本人太笨,所以想不出太好的算法,也就只能把两位数分别颠来倒去。渴望有
    高手写个高明的算法来学习学习。

        现贴出最笨的代码,就算是抛砖引玉罢 。

------------------------------------------------------------------------------*/
#include<stdio.h>
int fz(int a)
{
    if(a==2)      return 5;
    else if(a==5) return 2;
    else if(a==6) return 9;
    else if(a==9) return 6;
    else  return a;
}

int input()
{
    int a;
    while(1)
    {
        printf("input a:\n");
        scanf("%d",&a);
        if(a<10||a>99)    printf("error\n");
        else return a;
    }
}
void sort(int a[],int n)
{
    int i,j,tmp;
    for(i=0;i<=n;++i)
        for(j=i+1;j<=n;++j)
            if(a[i]>a[j])
            {
                tmp=a[i];
                a[i]=a[j];
                a[j]=tmp;
            }
}
void print(int a[],int n,int num)
{
    int i;
    for(i=0;i<=n;++i)
        printf("%d  ",a[i]);
    printf("\n");
    for(i=0;i<=n;++i)
        if(num<a[i])    break;
    if(i<n) printf("最小翻转数为:%d\n",a[i]);
    else    printf("这个数没有最小翻转数\n");
}
int main(void)
{
    int a,n=0;
    int a1,a2,_a1,_a2;
    int num[8];
    a=input();
    a1=a/10,a2=a%10;
    _a1=fz(a1);
    _a2=fz(a2);
    num[0]=a1*10+a2;
    num[1]=a2*10+a1;
    num[2]=_a1*10+a2;
    num[3]=a2*10+_a1;
    num[4]=_a2*10+a1;
    num[5]=a1*10+_a2;
    num[6]=_a1*10+_a2;
    num[7]=_a2*10+_a1;
    sort(num,7);
    print(num,7,a);
    return 0;
}

2008-11-07 09:59
Tchong
Rank: 1
等 级:新手上路
帖 子:117
专家分:0
注 册:2008-10-17
收藏
得分:0 
thank you very much
2008-11-09 22:02
快速回复:请教一下,这个怎样做
数据加载中...
 
   



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

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