PC版Dev-C++6.7.5版本9进制计算器程序代码

#include
#include
#include
using namespace std;

// 将九进制数转换为十进制
int nonaryToDecimal(string num) {
int decimal = 0;
int power = 0;
for (int i = num.size() - 1; i >= 0; i–) {
int digit = num[i] - ‘0’;
if (digit < 0 || digit > 8) {
cout << “输入的不是有效的九进制数!” << endl;
return -1;
}
decimal += digit * pow(9, power);
power++;
}
return decimal;
}

// 将十进制转换为九进制
string decimalToNonary(int num) {
string nonary;
while (num > 0) {
nonary += (num % 9) + ‘0’;
num /= 9;
}
reverse(nonary.begin(), nonary.end());
return nonary;
}

// 加法
string addNonary(string num1, string num2) {
int decimal1 = nonaryToDecimal(num1);
int decimal2 = nonaryToDecimal(num2);
if (decimal1 == -1 || decimal2 == -1) {
return “错误: 无效的输入”;
}
int sum = decimal1 + decimal2;
return decimalToNonary(sum);
}

// 减法
string subtractNonary(string num1, string num2) {
int decimal1 = nonaryToDecimal(num1);
int decimal2 = nonaryToDecimal(num2);
if (decimal1 == -1 || decimal2 == -1) {
return “错误: 无效的输入”;
}
int difference = decimal1 - decimal2;
if (difference < 0) {
return “错误: 结果为负数”;
}
return decimalToNonary(difference);
}

// 乘法
string multiplyNonary(string num1, string num2) {
int decimal1 = nonaryToDecimal(num1);
int decimal2 = nonaryToDecimal(num2);
if (decimal1 == -1 || decimal2 == -1) {
return “错误: 无效的输入”;
}
int product = decimal1 * decimal2;
return decimalToNonary(product);
}

// 除法
string divideNonary(string num1, string num2) {
int decimal1 = nonaryToDecimal(num1);
int decimal2 = nonaryToDecimal(num2);
if (decimal1 == -1 || decimal2 == -1) {
return “错误: 无效的输入”;
}
if (decimal2 == 0) {
return “错误: 除数不能为 0”;
}
int quotient = decimal1 / decimal2;
return decimalToNonary(quotient);
}

// 平方根
string squareRootNonary(string num) {
int decimal = nonaryToDecimal(num);
if (decimal == -1) {
return “错误: 无效的输入”;
}
if (decimal < 0) {
return “错误: 不能计算负数的平方根”;
}
double root = sqrt(decimal);
return decimalToNonary(static_cast(root));
}

// 幂运算
string powerNonary(string num, int exponent) {
int decimal = nonaryToDecimal(num);
if (decimal == -1) {
return “错误: 无效的输入”;
}
int powerResult = static_cast(pow(decimal, exponent));
return decimalToNonary(powerResult);
}

// 阶乘
string factorialNonary(string num) {
int decimal = nonaryToDecimal(num);
if (decimal == -1) {
return “错误: 无效的输入”;
}
if (decimal < 0) {
return “错误: 负数没有阶乘”;
}
int fact = 1;
for (int i = 1; i <= decimal; i++) {
fact *= i;
}
return decimalToNonary(fact);
}

int main() {
int choice;
string num1, num2, result;

do {
    cout << "1. 加法" << endl;
    cout << "2. 减法" << endl;
    cout << "3. 乘法" << endl;
    cout << "4. 除法" << endl;
    cout << "5. 平方根" << endl;
    cout << "6. 幂运算" << endl;
    cout << "7. 阶乘" << endl;
    cout << "8. 继续" << endl;
    cout << "9. 退出" << endl;
    cout << "请选择: ";
    cin >> choice;

    switch (choice) {
        case 1:
            cout << "请输入第一个九进制数: ";
            cin >> num1;
            cout << "请输入第二个九进制数: ";
            cin >> num2;
            result = addNonary(num1, num2);
            cout << "结果: " << result << endl;
            break;
        case 2:
            cout << "请输入被减数(九进制): ";
            cin >> num1;
            cout << "请输入减数(九进制): ";
            cin >> num2;
            result = subtractNonary(num1, num2);
            cout << "结果: " << result << endl;
            break;
        case 3:
            cout << "请输入第一个九进制数: ";
            cin >> num1;
            cout << "请输入第二个九进制数: ";
            cin >> num2;
            result = multiplyNonary(num1, num2);
            cout << "结果: " << result << endl;
            break;
        case 4:
            cout << "请输入被除数(九进制): ";
            cin >> num1;
            cout << "请输入除数(九进制): ";
            cin >> num2;
            result = divideNonary(num1, num2);
            cout << "结果: " << result << endl;
            break;
        case 5:
            cout << "请输入要计算平方根的九进制数: ";
            cin >> num1;
            result = squareRootNonary(num1);
            cout << "结果: " << result << endl;
            break;
        case 6:
            cout << "请输入底数(九进制): ";
            cin >> num1;
            int exponent;
            cout << "请输入指数: ";
            cin >> exponent;
            result = powerNonary(num1, exponent);
            cout << "结果: " << result << endl;
            break;
        case 7:
            cout << "请输入要求阶乘的九进制数: ";
            cin >> num1;
            result = factorialNonary(num1);
            cout << "结果: " << result << endl;
            break;
        case 8:
            cout << "继续进行其他操作..." << endl;
            break;
        case 9:
            cout << "退出系统!" << endl;
            break;
        default:
            cout << "无效的选择,请重新输入!" << endl;
    }
} while (choice!= 9);

return 0;

}

  • 25
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

EYYLTV

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值