PAT乙级1002:写出这个数

题目:


题解:

#include<iostream>
#include<string>
using namespace std;
int main()
{
	string str;
	cin >> str;
	int sum = 0;
	string str1[10]={ "ling","yi","er","san","si","wu","liu","qi","ba","jiu" };
	for (unsigned int i= 0;i<str.length();i++)
	{
		sum += (str[i] - '0');
	}
	string num = to_string(sum);
    //之所以要用无符号的int,因为length()取的值就是无符号整型,不然编译器会警告
	for (unsigned int j = 0; j < num.length(); j++)
	{
		cout <<str1[num[j]-'0'];
		if (j != num.length() - 1)
			cout << " ";
	}
	cout << endl;
	return 0;
}

踩坑:

  • 误认为string保存的字符串会有上限,会超过题目要求的长度。
string c;
cout << c.max_size()<<endl; //输出4294967294

        最后发现是我考虑多了,string在我这台电脑上能装下10亿个字符,而题目上说n小于10的100次方,顶多就是100个数字,和string能装下的字符完全不在一个级别上,所以说完全不用去考虑string会不会装不下的这个问题,可以看作是无限制的。

  • 怎么把字符装换成数字

        通过ASCII码,因为‘0’对应48,所以字符减去‘0’或48就可以把该字符转换成数字了(‘c’-'0')。

  • 把数字转换成字符串

       用C++11特性,to_string()函数。

       同样的,把字符串转换成数字有:

                stoi(string to int)

                stod(string to double)

                stof (string to float)
                stold (string to long double)

                stol (string to long)
                stoll (string to long long)
                stoul (string to unsigned long)
                stoull (string to unsigned long long)

  • string类型的数组,每个元素的大小可以不一样

猜你喜欢

转载自blog.csdn.net/Lewis_lxc/article/details/82942417