题解 | #尼科彻斯定理#

尼科彻斯定理

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);
        }
    }
}

这题的话,还是注意好好看看题目本身,然后找规律的

全部评论

相关推荐

感谢信收割机Rain:他昨天还和我打瓦,今天咋这样发邮件😅
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务