C++实现阿姆斯特朗数检查程序

需积分: 14 0 下载量 43 浏览量 更新于2024-09-11 收藏 1KB TXT 举报
"阿姆斯特朗数是指一个n位数,它的每个位上的数字的n次幂之和等于它本身。例如,371是一个阿姆斯特朗数,因为3^3 + 7^3 + 1^3 = 371。这个程序是用C++编写的一个用于检查和输出阿姆斯特朗数的实现。" 在C++代码中,定义了一个名为`ArmStrong`的类,用于处理阿姆斯特朗数的相关操作。这个类包含以下几个成员: 1. `void Set(int Number)`: 用于设置输入的数字。 2. `void SetS()`: 初始化存储数字位的栈。 3. `void Resolve()`: 将输入的数字分解并存储在栈中。 4. `int* GetStack()`: 返回存储数字位的栈。 5. `int GetSize()`: 返回栈的大小,即数字的位数。 6. `int GetNumber()`: 返回原始输入的数字。 此外,还有一个辅助函数`int Check(int* stack, int size, int number)`,用于检查一个数是否是阿姆斯特朗数。这个函数根据数字的位数(由`size`表示)进行不同的计算,如3位数或4位数,然后比较计算结果与原数是否相等。 在`main`函数中,程序会检查用户输入的数字是否为阿姆斯特朗数,并可能输出相关信息。然而,代码中缺少了`main`函数的结束部分,通常应该有一个`return 0;`来表示程序正常结束。 为了完整运行这段代码,你需要补充`main`函数的剩余部分,例如,让用户输入一个整数,然后创建一个`ArmStrong`对象,调用其方法来处理这个数字,并通过`Check`函数判断是否为阿姆斯特朗数。如果找到阿姆斯特朗数,可以打印出来。 例如,你可以这样扩展`main`函数: ```cpp void main() { int count, input; cout << "请输入一个整数:"; cin >> input; ArmStrong num; num.Set(input); num.Resolve(); if (Check(num.GetStack(), num.GetSize(), num.GetNumber())) cout << input << " 是一个阿姆斯特朗数。\n"; else cout << input << " 不是一个阿姆斯特朗数。\n"; return 0; } ``` 这样,程序就能接收用户输入,检查是否为阿姆斯特朗数,并给出相应的反馈。