我正在解决一个问题,其中任务是在用户提到的给定行输出帕斯卡三角形的结果。
https://leetcode.com/problems/pascals-triangle-ii/
我编写了我的解决方案,该解决方案在存储大量阶乘结果时存在问题。
vector<int> getRow(int rowIndex) {
vector<int> v;
int C = 1;
v.push_back(1);
for (int i = 1; i <= rowIndex; i++)
{
printf("%d ", C);
C = C * (rowIndex +1 - i) / i;
v.push_back(C);
}
return v;
}
在经历这些问题时,
并通过其他一些来源,我进行了以下更改,这给了我所需的结果。
C = (unsigned long long)C * (rowIndex +1 - i) / i;
由于“C”是int类型并且我的向量 v 存储int,我想知道为什么强制转换unsigned long long仍然会给我有效的结果。