题解 | #尼科彻斯定理#
尼科彻斯定理
https://www.nowcoder.com/practice/dbace3a5b3c4480e86ee3277f3fe1e85
#include <iostream>
using namespace std;
// 此题的思路是看m的二次方,要是m的二次方为奇数,那么带本身分别输出前面的m/2个奇数
// 要是m的二次方是偶数,那么不带本身分别输出前面的m/2个奇数
int main() {
int n, sum, cnt, a[100]= {0}, flag;
cin >> n;
sum = n*n*n;
cnt = n*n;
if(cnt % 2 == 0) // 假设现在n = 4
{
flag = 0;
for(int i = -(n/2); i < (n/2); i++) // 不输出其本身
{
if(flag == 1)
cout << '+';
cout<< cnt+(i*2)+1;
flag = 1;
}
}
else{ // n = 3 输出其本身
for(int i = -(n/2); i <= (n/2); i++)
{
if(i != -(n/2)) // 此处的话, 其实不同flag 会看起来比较简单点儿,因为我们只要保证输出的不是第一个数的时候在输入'+' 即可
cout << '+';
cout<< cnt+(i*2);
}
}
}
这题的话,还是注意好好看看题目本身,然后找规律的