• 2019年寒假作业2


    1.实验代码

    include<stdio.h>
    int main ()
    {
    char NUM[10]={'a','b','c','d','e','f','g','h','i','j'}; //存数字
    char UNIT[10]={0,0,'S','B','Q','W','S','B','Q','Y'};//存单位,为将下标与位数对应,前两个单元存0
    char RESULT[17];//存结果,最多存9个数字,8个单位
    int n,k=0,bitnum=0,cur,pre; //定义输入数字,结果数组索引,位数,当前位,前一位

    scanf("%d", &n);

    if(n==0)
    {
    printf("a");
    return 0;
    }
    while(n!=0)
    {
    cur = n % 10;
    n /= 10;
    bitnum++;

    if(cur)
    {
    if(bitnum>1)//如果不为个位,存单位
    RESULT[k++] = UNIT[bitnum];

    RESULT[k++] = NUM[cur];//无论如何,存数字
    }
    else//如果当前位为0
    {
    if(bitnum==5)
    RESULT[k++] = UNIT[bitnum];

    if(pre!=0&&bitnum!=4&&bitnum!=1)//若不为万位,千位,个位,且前一位不为0
    RESULT[k++]=NUM[cur];//存当前的数字0
    }

    pre=cur;//注意及时保存当前位
    }
    for(int i=k-1;i>=0;i--)//倒序输出结果
    printf("%c",RESULT[i]);

    return 0;
    }

  • 相关阅读:
    排序二——交换排序
    桥接模式 Bridge
    外观模式Facade(解耦)
    装饰模式和代理模式的区别
    代理模式 proxy
    装饰器模式 Decorator
    适配器模式
    android launcher-启动过程
    ubuntu 编译openwrt
    Eclipse Memory Analyzer tool(MAT)
  • 原文地址:https://www.cnblogs.com/Emotional/p/10414943.html
Copyright © 2020-2023  润新知