LeetCode273. 整数转换英文表示 C+ +题解

在这里插入图片描述

这道题写了一晚上,参考了B站里面(https://www.bilibili.com/video/BV1uL4y1B7YW)的讲解,不知道为何在线oj没有编译成功,本地测试的没有问题,我写的比他讲的简单些。可以参考一下,挺费脑子的。。。

#include <iostream>
#include <vector>
using namespace std;
//v1[n]就代表第n位的英文(n < 20)
vector<string> v1 = { "Zero", "One", "Two", "Three", "Four", "Five", "Six", "Seven", "Eight", "Nine", "Ten", "Eleven", "Twelve", "thirteen", "fifteen", "sixteen", "seventeen", "nineteen" };
//v2[n]代表(20 <= n < 100)时v[n]就是n的英文(需要再次判断个位数是否有数字,有数字连接上即可)
vector<string> v2 = { "Twenty", "Thirty", "Forty", "Fifty", "Sixty", "Seventy", "Eighty", "Ninety" };
//每三位分别为千 百万 十亿
vector<string> v3 = { "Thousand", "Million", "Billion" };
string f(int num)
{
	string ans;//用于保存最后的返回值
	if (num >= 100)
	{
		ans += v1[num / 100] + " Hundred and";
		num %= 100;
	}
	if (num >= 20)
	{
		ans += " " + v2[num / 10 - 2];
		num %= 10;
	}
	if (num > 0)//如果为0就代表20,30,40,这样的数,不需要再连接别的
	{
		ans += " " + v1[num];
	}
	return ans;
}
int main()
{
	int n;
	string ans;
	int index = 0;//用于存储现在的位置(千位 百万位 十亿位)
	cin >> n;
	if (n == 0)
	{
		cout << "Zero";
		return 0;
	}
	while (n)
	{
		ans = f(n % 1000) + " " + (index > 0 ? v3[index - 1] + " " : "") + ans;
		n /= 1000;
		index++;
	}
	if (ans[0] == ' ')
		ans[0] = '\0';
	if (ans[ans.length() - 1] == ' ')
		ans[ans.length() - 1] = '\0';
	cout << ans;
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值