Time Limit:1000MS  Memory Limit:65535K

题型: 编程题   语言: 无限制

描述

在那个风起云涌的SCAU ACM里,有两位人生赢家,他们分别是大洲Takio神和Blue神。      (尤其是blue神。)
由于这两位人生赢家代码能力强,才高八斗,学富五车,英俊潇洒,玉树临风,独步江湖,呼风唤雨,妹子纷至沓来。
而小邪由于太渣了,只能默默地帮他们记录下他们换了多少个妹子。
以上背景纯属题目需要,其实两位大神是很专情的。
终于有一天,小邪计算出他们身边妹子的总数n,想要给Takio神和Blue神。
但是Takio神和Blue神的邮箱是使用英文的,而小邪的英语又很渣,于是无法将n翻译成英语发过去。
但是,小邪想到了你——聪明的14级新生,向你寻求答案。 出题人:K·小邪

输入格式

第一行是一个整数t(t <= 100),代表样例个数
对于每个样例有一个整数n(0<=n<=2000000000)

输出格式

对于每个n,输出其英文表现形式,具体格式见样例输出

输入样例

4
5
121
1010
1008611

输出样例

five
one hundred and twenty-one
one thousand and ten
one million, eight thousand, six hundred and eleven

Hint

输出不一定符合英语规范,但是要符合Sample的规范
对于一个n>1000,若n%1000 >= 100(%代表取余操作)且不为0,且在n%1000对应的英文输出前(如果存在)用","相连而不是"and" 需要用到的英文单词为(不包括引号):
"zero","one","two","three","four","five","six","seven","eight","nine"
"ten","eleven","twelve","thirteen","fourteen","fifteen","sixteen","seventeen","eighteen","nineteen"
"twenty","thirty","forty","fifty","sixty","seventy","eighty","ninety"
"hundred","thousand","million","billion"
分别代表
0,1,2,3,4,5,6,7,8,9
10,11,12,13,14,15,16,17,18,19
20,30,40,50,60,70,80,90
100,1000,1000000,1000000000
#include<stdio.h>
#include<string.h>
void go(void);
int a[],k,num;
int leap,leap1,leap2,leap3,leap4,leap5,leap6,leap7,leap8,leap9,leap10;
char str[][]=
{
"zero","one","two","three","four","five","six",
"seven","eight","nine","ten","eleven","twelve",
"thirteen","fourteen","fifteen","sixteen",
"seventeen","eighteen","nineteen","twenty"
}; int main()
{
int i,k,T; strcpy(str[],"thirty");
strcpy(str[],"forty");
strcpy(str[],"fifty");
strcpy(str[],"sixty");
strcpy(str[],"seventy");
strcpy(str[],"eighty");
strcpy(str[],"ninety");
scanf("%d",&T);
while(T--)
{
memset(a,,sizeof(a));
leap=leap1=leap2=leap3=leap4=leap5=leap6=leap7=leap8=leap9=leap10=;
scanf("%d",&num);
i=;
k=num;
if(num>&&num%>=) leap=;
while(k!=)
{
a[i++]=k%;
k=k/;
}
k=i-;
if(k==||k==) {printf("%s\n",str[num]);continue;}
if(k==) {if(num>&&num<=||num%==) printf("%s\n",str[num]);
else printf("%s-%s\n",str[num-num%],str[num%]);continue;}
go();
printf("\n"); }
return ;
}
void go(void)
{
int temp1,temp2,temp3; if(a[]) {printf("%s billion",str[a[]]);leap10=;}
if((leap&&k>=)||(leap10&&a[]!=)||(leap10&&a[]!=)||(leap10&&a[]!=)||(leap10&&a[]!=)||(leap10&&a[]!=)||(leap10&&a[]!=))
printf(", "); if(a[]) {printf("%s hundred",str[a[]]);leap9=;}
temp1=a[]*+a[];
if(leap9&&temp1!=) printf(" and ");
if(temp1!=)
{
if((temp1>&&temp1<=)||temp1%==) printf("%s",str[temp1]);
else printf("%s-%s",str[temp1-temp1%],str[temp1%]);
leap7=;
}
if(leap9||leap7) printf(" million");
if((leap&&k>=)||((leap9&&a[]!=)||(leap7&&a[]!=))||((leap9&&a[]!=)||(leap7&&a[]!=))||((leap9&&a[]!=)||(leap7&&a[]!=))) printf(", "); if(a[]) {printf("%s hundred",str[a[]]);leap6=;}
temp2=a[]*+a[];
if(leap6&&temp2!=) printf(" and ");
if(temp2!=)
{
if((temp2>&&temp2<=)||temp2%==) printf("%s",str[temp2]);
else printf("%s-%s",str[temp2-temp2%],str[temp2%]);
leap4=;
}
if(leap6||leap4) printf(" thousand");
if(leap) printf(", ");
if(a[]) {printf("%s hundred",str[a[]]);leap3=;}
temp3=a[]*+a[];
if((leap3&&temp3!=)||(a[]==&&temp3!=)) printf(" and ");
if(temp3!=)
{
if((temp3>&&temp3<=)||temp3%==) printf("%s",str[temp3]);
else printf("%s-%s",str[temp3-temp3%],str[temp3%]);
}
}

F Takio与Blue的人生赢家之战的更多相关文章

  1. JavaScript Array

    1.常用方法 // 数组构造 var a = new Array(20); // 长度为20的数组 var b = new Array('red', 'blue', 'white'); var c = ...

  2. iOS - 二维码扫描和应用跳转

    序言 前面我们已经调到过怎么制作二维码,在我们能够生成二维码之后,如何对二维码进行扫描呢? 在iOS7之前,大部分应用中使用的二维码扫描是第三方的扫描框架,例如ZXing或者ZBar.使用时集成麻烦, ...

  3. gradient color

    http://www.cnblogs.com/YouXianMing/p/3793913.html layer 不能自动autolay, 只能在viewDidLayout里面设置宽度 - (void) ...

  4. javaSE第二十五天

    第二十五天    399 1:如何让Netbeans的东西Eclipse能访问.    399 2:GUI(了解)    399 (1)用户图形界面    399 (2)两个包:    399 (3) ...

  5. C语言学习资料(转载)

    ◆经典C源程序100例:http://post.baidu.com/f?kz=8618367 ◆时钟的驻留程序:http://post.baidu.com/f?kz=10822377 ◆数据结构暨若干 ...

  6. UI:tomcat(说话小程序)、相框动画、UISgmentcontrol、UISwitch

    UISegmentedControl 分段控件 //1. UISegmentedControl 分段控件 (就是一个一个的按钮) //分段显示的标题是以一个数组存储的 NSArray * titles ...

  7. 《JavaScript高级程序设计》心得笔记-----第二篇章

    第五章 9.Function函数 1)         函数内部有两个特殊的对象: (1)       arguments(主要用于保存函数参数,有一个属性callee,这是一个指针,指向拥有argu ...

  8. JSF 2 radio buttons example

    In JSF, "h:selectOneRadio" tag is used to render a set of HTML input element of type " ...

  9. GUI编程笔记(java)08:GUI通过鼠标移动到按钮上更改背景色案例

    首先我们看看源代码如下: package cn.itcast_06; import java.awt.Button; import java.awt.Color; import java.awt.Fl ...

随机推荐

  1. Robberies

     Robberies Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit S ...

  2. Hibernate执行原生SQL返回List<Map>类型结果集

    我是学java出身的,web是我主要一块: 在做项目的时候最让人别扭的就是hibernate查询大都是查询出List<T>(T指代对应实体类)类型 如果这时候我用的联合查询,那么返回都就是 ...

  3. VS2010调用Com组件

    Com组件开发过程中用的不多,资料也不多,故记录开发Com组件中的部分问题. 在这一篇文章里,讲解了如何使用VS2010创建Com组件.现在基于该文章创建的Com组件接口,创建VC++项目来调用该接口 ...

  4. 最长递增子序列问题 nyoj 17单调递增最长子序列 nyoj 79拦截导弹

    一,    最长递增子序列问题的描述 设L=<a1,a2,…,an>是n个不同的实数的序列,L的递增子序列是这样一个子序列Lin=<aK1,ak2,…,akm>,其中k1< ...

  5. Controller之间传递数据:Block传值

    http://itjoy.org/?p=420 前边我们介绍过属性传值和协议传值,这里介绍一下块传值,块类似于C中的函数指针.在Controller中传递数据非常方便,还是继续上一章的例子,将数据从S ...

  6. VIM中的折叠命令

    参考:http://blog.csdn.net/bruce0532/article/details/8497284 za:在折叠与展开间自由转换 zf:创建折叠 示例:zf 3j    #本行及以下3 ...

  7. Html5 History API解析

    浏览器前进与回退操作 在传统的浏览器中我们只能通过调用window.history对象的 forward() . back() 或 go(number|url) 方法来进行页面的前进.回退或跳转到某一 ...

  8. 【转】ByteArrayOutputStream和ByteArrayInputStream详解

    ByteArrayOutputStream类是在创建它的实例时,程序内部创建一个byte型别数组的缓冲区,然后利用ByteArrayOutputStream和ByteArrayInputStream的 ...

  9. 理解和解决MySQL乱码问题

    本文将详细介绍MySQL乱码的成因和具体的解决方案 在阅读本文之前,强烈建议对字符集编码概念还比较模糊的同学 阅读下博主之前对相关概念的一篇科普:十分钟搞清字符集和字符编码 MySQL出现乱码的原因 ...

  10. canvas API ,通俗的canvas基础知识(二)

    上文我们讲到了画一条线,画矩形,写文字,总算是有了一个好的开头,如果还没有看的同学出门左转,先看看那篇,这里就不多做叙述了,接下来我们看比较复杂的一些属性和方法! 讲之前呢,我还是想温习一下,毕竟上文 ...