题解 | #尼科彻斯定理#
尼科彻斯定理
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); } } }
这题的话,还是注意好好看看题目本身,然后找规律的