Problem C: 整数的封装
原创
©著作权归作者所有:来自51CTO博客作者软糖酱八号机的原创作品,请联系作者获取转载授权,否则将追究法律责任
Problem C: 整数的封装
Description
现在,请编写一个Integer类,将整数封装起来。目前,只需要你来实现最基本的功能:
1. 具有2个构造函数:
(1)Integer::Integer(int):根据参数构建一个整数对象。
(2)Integer::Integer(char*, int):根据给定的字符串和进制来构建一个整数对象。
2. 具有一个int Integer::getValue()方法,用于返回Integer类中所封装的整数的具体数值。
Input
输入分为多行。
第一行是一个正整数M,表示其后面的M行为M个整数,每行一个整数。
第M+2行是一个正整数N,表示其后有N行。每行由利用一个空格隔开的2部分组成:前半部分是一个字符串,后半部分是该字符串所使用的进制。
注意:
1. 所有的输入,均在int类型的表示范围内,且所有的输入均为合法输入。
2. 利用0~9和a~z可最大可以表示36进制的数值。
Output
输出为M+N行,每行为一个十进制整数,且输出顺序应与输入顺序相同。
#include <iostream>
#include <cctype>
using namespace std;
class Integer {
private:
int x;
public:
Integer(int x) : x(x) {}
Integer(char *str, int base) {
int flag = 1, sum = 0;
for (int i = 0; str[i] != '\0'; i++) {
if (str[i] == '-') flag = -1;
else if (isdigit(str[i])) {
sum = sum * base + str[i] - '0';
}
else if (isalpha(str[i])) {
if (isupper(str[i])) str[i] += 32;
sum = sum * base + str[i] - 'a' + 10;
}
}
x = flag * sum;
}
int getValue() { return x; }
};
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;
}