蓝桥杯练习 - 阶乘计算(Vector 容器)

举例

16 * 24 = 384
容器状态:61
6 * 24 = 144,修改 6 为 4 进 14,容器状态:41
1 * 24 = 24,24 + 14 = 38,修改 1 为 8 进 3,容器状态:48
添加 3,容器状态:483

AC

#include <iostream>
#include <vector>
using namespace std;

int main() {
	int n;
	cin >> n;
	vector<int> va;
	va.push_back(1); 
	for (int i = 2; i <= n; ++i) {
		int rest = 0;
		for (int j = 0; j < va.size(); ++j) {
			int temp = va[j] * i + rest;
			rest = temp / 10;
			va[j] = temp % 10;
		}
		while (rest) { //rest 可能 >= 10
			va.push_back(rest % 10);
			rest /= 10;
		} 
	}
	for (int i = va.size() - 1; i >= 0; --i)
		cout << va.at(i);
	return 0;
}

参考资料

蓝桥杯 练习系统 基础练习 阶乘计算(C++)_Mac_Jie 的博客-CSDN 博客

上一篇:安卓逆向学习---初始APK、Dalvik字节码以及Smali


下一篇:vs下调试程序时,把信息打印到输出窗口