判断一个数高位到低位是否是从小到大排列

判断一个数高位到低位是否是从小到大排列,第1张

判断一个数高位到低位是否是从小到大排列 判断一个数高位到低位是否是从小到大排列

输入一批正整数(以零或负数为结束标志),判断每个数从高位到低位的各位数字是否按值从小到大排列。要求定义和调用函数fun(m)判断m中各位数字是否按值从小到大排列,满足条件返回1,否则返回0。

#include 
int fun(int n)
{
    int old_digit = 10;
    int cur_digit;
    while(n > 0)
    {
        cur_digit = n % 10;
        if(cur_digit > old_digit)//这个判断条件是给第二轮循环看的,第一轮循环只看其他语句,相当于一个对第一轮没有影响的但是之后需要的判断条件
            return 0;
        old_digit = cur_digit;//第一轮循环是一个准备工作,好像是可以拿到循环外边做的,但是实际做了发现并不好,因为这个语句确实是需要循环来提供下一步的依托的
                            //如果非要提到外边会造成语句的赘余
        n /= 10;
    }
    return 1;
}
int main()
{
    int n;
    scanf("%d",&n);
    while(n>0)
    {
        if(fun(n))
            printf("yes");
        else
            printf("no");
        scanf("%d",&n);
    }
    return 0;
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5659292.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存