zoukankan      html  css  js  c++  java
  • 算法实现数字编号翻译为英文

    将编号“翻译”成英文。例35706“翻译”成three-five-seven-zero-six。看到题目的第一反应是对数字进行求余逐个分开,之后用switch  case:进行分类判断。再创建一个字符串数组进行存储判断到的字符串,最后进行倒叙输出,就得到编号的翻译内容。方法一般,可以接受。如果我们进一步分析,便会发现下面我要介绍的方法,方便简洁了不少,我们应在功能实现的同时考虑下算法的优劣,以及代码的优雅与否。下面为另外一种方法的介绍:

    我们可以创建字符串数组存储0-9的英文字符串,即:

    char eng[10][6]={"zero","one","two","three","four","five","six","seven","eight","nine"}

    创建数组 num[10] 用于存储数字编号。

    最后关键一步:存储的数字数组倒叙依次在eng[]的字符串数组中根据下标查找。即:eng[num[0]]。

    代码如下(C语言版):

     1 #include <stdio.h>
     2 #include <stdlib.h>
     3 int main()
     4 {
     5 char eng[10][6]={"zero","one","two","three",
     6 "four","five","six","seven","eight","nine"};
     7 int n,end=0,num[10];
     8 printf("输入你要翻译的数字:");
     9 scanf("%d",&n);
    10 int temp=n;
    11 while(temp!=0){
    12 num[end++]=temp%10;
    13 temp/=10;
    14 }
    15 end-=1;
    16 for(;end>0;end--){
    17 printf("%s-",eng[num[end]]);
    18 }
    19 printf("%s",eng[num[0]]);
    20 return 0;
    21 }

    程序运行如图:

    附注:原创不易,转载说明出处。

    http://www.cnblogs.com/xsmile

    ----------------------------------------声明----------------------------------------
    作者:xsmile
    仅自己学习过程技术总结,如有哪里有误的地方,欢迎指正。
    原创不易,如需转载,请注明出处及地址 www.cnblogs.com/xsmile
    ----------------------------------------end----------------------------------------
  • 相关阅读:
    作业
    动手动脑
    作业
    《大道至简》第二章读后感
    《大道至简》第一章读后感
    局域网内网站发布(三)
    局域网内网站发布(二)
    局域网内网站发布(一)
    管理系统
    台式机没有声音
  • 原文地址:https://www.cnblogs.com/xsmile/p/7725845.html
Copyright © 2011-2022 走看看