POJ2121 Inglish-Number Translator
#include <iostream>
#include <string>
#include <map>
#include <algorithm>
using namespace std;
map<string, int> mapTable;
void initMapTable()
{
mapTable["zero"] = 0;
mapTable["one"] = 1;
mapTable["two"] = 2;
mapTable["three"] = 3;
mapTable["four"] = 4;
mapTable["five"] = 5;
mapTable["six"] = 6;
mapTable["seven"] = 7;
mapTable["eight"] = 8;
mapTable["nine"] = 9;
mapTable["ten"] = 10;
mapTable["eleven"] = 11;
mapTable["twelve"] = 12;
mapTable["thirteen"] = 13;
mapTable["fourteen"] = 14;
mapTable["fifteen"] = 15;
mapTable["sixteen"] = 16;
mapTable["seventeen"] = 17;
mapTable["eighteen"] = 18;
mapTable["nineteen"] = 19;
mapTable["twenty"] = 20;
mapTable["thirty"] = 30;
mapTable["forty"] = 40;
mapTable["fifty"] = 50;
mapTable["sixty"] = 60;
mapTable["seventy"] = 70;
mapTable["eighty"] = 80;
mapTable["hundred"] = 100;
mapTable["thousand"] = 1000;
mapTable["million"] = 1000000;
}
void solve(string& str)
{
string::size_type pos = str.find_first_of(' ');
if (pos == string::npos)
{//只有一个单词
if (str == "negative")
{
cout << "-0" << endl;
}
else if (mapTable.find(str) != mapTable.end())
{
cout << mapTable[str] << endl;
}
}
else
{//至少个单词
string input = str;
int sum = 0,msum = 0,tsum = 0,hsum = 0;
bool bMinus = false;
int count = 0;
string::iterator start = input.begin();
string::iterator end = input.end();
do
{
string word;
end = find(start,input.end(),' ');//找到分隔符
copy(start,end,back_inserter(word));
++count;//单词计数
if (word == "negative")
{
bMinus = true;
}
else
{
if (count == 2 && word == "zero")
{
bMinus = false;
}
int curNum = mapTable[word];
if (curNum == 100)
{
hsum = sum * 100;
sum = 0;
}
else if (curNum == 1000)
{
tsum = (hsum + sum) * 1000;
hsum = 0;
sum = 0;
}
else if (curNum == 1000000)
{
msum = (tsum + hsum + sum) * 1000000;
tsum = 0;
hsum = 0;
sum = 0;
}
else
{
sum += curNum;
}
}
if (end == input.end())
{
if (bMinus)
cout << "-";
cout << msum +tsum + hsum + sum << endl;
break;
}
start = ++end;
} while (end != input.end());
}
}
int main()
{
string str;
initMapTable();
while(getline(cin,str))
{
if (str.length() == 0 || str.length() == 1)
continue;
solve(str);
}
return 0;
}
#include <string>
#include <map>
#include <algorithm>
using namespace std;
map<string, int> mapTable;
void initMapTable()
{
mapTable["zero"] = 0;
mapTable["one"] = 1;
mapTable["two"] = 2;
mapTable["three"] = 3;
mapTable["four"] = 4;
mapTable["five"] = 5;
mapTable["six"] = 6;
mapTable["seven"] = 7;
mapTable["eight"] = 8;
mapTable["nine"] = 9;
mapTable["ten"] = 10;
mapTable["eleven"] = 11;
mapTable["twelve"] = 12;
mapTable["thirteen"] = 13;
mapTable["fourteen"] = 14;
mapTable["fifteen"] = 15;
mapTable["sixteen"] = 16;
mapTable["seventeen"] = 17;
mapTable["eighteen"] = 18;
mapTable["nineteen"] = 19;
mapTable["twenty"] = 20;
mapTable["thirty"] = 30;
mapTable["forty"] = 40;
mapTable["fifty"] = 50;
mapTable["sixty"] = 60;
mapTable["seventy"] = 70;
mapTable["eighty"] = 80;
mapTable["hundred"] = 100;
mapTable["thousand"] = 1000;
mapTable["million"] = 1000000;
}
void solve(string& str)
{
string::size_type pos = str.find_first_of(' ');
if (pos == string::npos)
{//只有一个单词
if (str == "negative")
{
cout << "-0" << endl;
}
else if (mapTable.find(str) != mapTable.end())
{
cout << mapTable[str] << endl;
}
}
else
{//至少个单词
string input = str;
int sum = 0,msum = 0,tsum = 0,hsum = 0;
bool bMinus = false;
int count = 0;
string::iterator start = input.begin();
string::iterator end = input.end();
do
{
string word;
end = find(start,input.end(),' ');//找到分隔符
copy(start,end,back_inserter(word));
++count;//单词计数
if (word == "negative")
{
bMinus = true;
}
else
{
if (count == 2 && word == "zero")
{
bMinus = false;
}
int curNum = mapTable[word];
if (curNum == 100)
{
hsum = sum * 100;
sum = 0;
}
else if (curNum == 1000)
{
tsum = (hsum + sum) * 1000;
hsum = 0;
sum = 0;
}
else if (curNum == 1000000)
{
msum = (tsum + hsum + sum) * 1000000;
tsum = 0;
hsum = 0;
sum = 0;
}
else
{
sum += curNum;
}
}
if (end == input.end())
{
if (bMinus)
cout << "-";
cout << msum +tsum + hsum + sum << endl;
break;
}
start = ++end;
} while (end != input.end());
}
}
int main()
{
string str;
initMapTable();
while(getline(cin,str))
{
if (str.length() == 0 || str.length() == 1)
continue;
solve(str);
}
return 0;
}
作者:洞庭散人
出处:http://phinecos.cnblogs.com/
本博客遵从Creative Commons Attribution 3.0 License,若用于非商业目的,您可以自由转载,但请保留原作者信息和文章链接URL。
posted on 2009-09-12 21:43 Phinecos(洞庭散人) 阅读(1148) 评论(0) 编辑 收藏 举报