zoukankan      html  css  js  c++  java
  • 给出一个不多于5位的正整数,求解三个问题。

    题目:给出一个不多于5位的正整数,要求:

    1.求出它是几位数;

    2.分别输出每一位数字;

    3.按逆序输出各位数字。

    解答

    第一问:

        int n,m=1;
      int a; scanf(
    "%d",&n);
      a=n;
    //方法一 printf("%d的位数是%d ",n,(int)log10(n)+1); //方法二 while(n>=10) { n=n/10; m++; }

    第二问:

            /*
        顺序输出各位数字
        */
        switch(m) {
            case 5: printf("%d",n/10000);n=n-n/10000*10000;
            case 4: printf("%d",n/1000);n=n-n/1000*1000;
            case 3: printf("%d",n/100);n=n-n/100*100;
            case 2: printf("%d",n/10);n=n-n/10*10;
            case 1: printf("%d
    ",n);
        }    

    第三问:

        /*
        逆序输出各位数字
        
        */
        while(a>0) {
            printf("%d",a%10);
            a =a/10;    
        }

    全部代码:

    #include<stdio.h>
    #include<math.h>
    int main() {
        int n,m=1;
        int a;
        scanf("%d",&n);
           while(n>=100000) {
            printf("请重新输入一个小于100000的数:");
            scanf("%f",&n);
        }
        a=n;
        //方法一
        printf("%d的位数是%d
    ",n,(int)log10(n)+1);   
        /*
        //方法二
        while(n>=10) {
            n=n/10;
            m++;
        }
        */
        /*
        顺序输出各位数字
        */
        switch(m) {
            case 5: printf("%d	",n/10000);n=n-n/10000*10000;
            case 4: printf("%d	",n/1000);n=n-n/1000*1000;
            case 3: printf("%d	",n/100);n=n-n/100*100;
            case 2: printf("%d	",n/10);n=n-n/10*10;
            case 1: printf("%d
    ",n);
        }
        /*
        逆序输出各位数字
        
        */
        while(a>0) {
            printf("%d",a%10);
            a =a/10;    
        }
        
        printf("
    ");
    
    return 0;
    }    
    View Code

    运行结果:

  • 相关阅读:
    web动静分离
    vm采用NAT方式连接时,设置静态ip
    nginx实现tcp负载均衡
    读取文件
    线程池源码分析
    mongodb操作
    bind
    Xss攻击
    json和java对象相互转换
    静态资源默认加载路径
  • 原文地址:https://www.cnblogs.com/lick468/p/9950453.html
Copyright © 2011-2022 走看看