Problem A: 整数的封装Time Limit: 1 Sec Memory Limit: 128 MB
Submit: 4330 Solved: 1643
[Submit][Status]Description现在,请编写一个Integer类,将整数封装起来。目前,只需要你来实现最基本的功能:
- 具有2个构造函数:
(1)Integer::Integer(int):根据参数构建一个整数对象。
(2)Integer::Integer(char*, int):根据给定的字符串和进制来构建一个整数对象。 - 具有一个int Integer::getValue()方法,用于返回Integer类中所封装的整数的具体数值。
Input输入分为多行。
第一行是一个正整数M,表示其后面的M行为M个整数,每行一个整数。
第M+2行是一个正整数N,表示其后有N行。每行由利用一个空格隔开的2部分组成:前半部分是一个字符串,后半部分是该字符串所使用的进制。
注意: - 所有的输入,均在int类型的表示范围内,且所有的输入均为合法输入。
- 利用09和az可最大可以表示36进制的数值。
Output输出为M+N行,每行为一个十进制整数,且输出顺序应与输入顺序相同。
Sample Input
2
999
-1999
4
0111 2
1a 16
z 36
a 16
Sample Output
999
-1999
7
26
35
10
HINTAppend Codeappend.cc,
#include<iostream>
#include<cstring>
#include<iomanip>
using namespace std;
class Integer{
private:
int a_;
public:
Integer(int a):a_(a){}
Integer(char* s,int t)
{
int len = strlen(s);
int flag = 1;
int sum = 0;
for(int i = 0;i < len;i++)
{
if(s[i] == '-')
{
flag = -1;
continue;
}
if(s[i] >= 'A' && s[i] <= 'Z')
{
s[i] += 32;
}
if(isalnum(s[i]))
{
sum *= t;
if(isdigit(s[i]))
{
sum += (s[i] -'0');
}
else
{
sum += (s[i] - 'a' + 10);
}
}
}
a_ = sum * flag;
}
int getValue(){return a_;}
};
int main()
{
char str[100];
int numOfData, numOfStr;
int data, i, radix;
cin>>numOfData;
for (i = 0; i < numOfData; i++){
cin>>data;
Integer anInteger(data);
cout<<anInteger.getValue()<<endl;
}
cin>>numOfStr;
for (i = 0; i < numOfStr; i++){
cin>>str>>radix;
Integer anInteger(str,radix);
cout<<anInteger.getValue()<<endl;
}
return 0;
}