• CodeForces..构建美丽数组.[简单].[情况判断].[特殊条件下的最小值奇偶问题]


    题目描述:


    题目解读:

    给定数组a[n],ai>0,问能否得到一个数组b[n],数组b中的元素都大于0且全奇or全偶。

    数组b中的元素bi=ai or ai-aj(1


    解题思路:

    数组b中的元素都大于0且全奇or全偶。分析所有情况:

    如果a[n]全为偶或全为奇,则b[n]全偶或全奇,必然满足要求;

    如果a[n]奇偶都有,想实现b[n]全偶或全奇,必然需要使用bi=ai-aj运算,

    对于减法: 奇-偶=奇;奇-奇=偶;偶-偶=偶;偶-奇=奇;

    对于值比较大的元素,可以自由选择减去奇数还是偶数(而且减去后还大于0),来实现最终的全奇全偶;唯一需要重点考虑的是最小元素的奇偶性,因为题目要求每个元素需要大于0,故最小元素无法通过减法运算改变奇偶性。

    如果最小值是奇数,那其他偶数-奇数,都可变为奇数,即使是最小偶数也可以减最小奇数来变为奇数,故可以满足要求;

    如果最小值为偶数,其他奇数-偶数,还是奇数,无法变偶;奇数-奇数可以变偶数,但是最小奇数没有奇数给它减,所以无法满足要求。

    综上所述,返回NO的唯一条件是,数组元素奇偶都有,且最小值为偶数。


    代码实现:

    1. #define _CRT_SECURE_NO_WARNINGS 1
    2. #include
    3. #define MAX 200000 //注意题目中要求的变量取值范围
    4. #include
    5. using namespace std;
    6. void Solve() {
    7. int n,i=0;
    8. int num[MAX];
    9. int flgodd = 0,flgeven=0;
    10. int minnum = 1e9;
    11. scanf("%d", &n);
    12. for (i = 0; i < n; i++) {
    13. scanf("%d", &num[i]);
    14. if (num[i] % 2 == 1) { //奇数
    15. flgodd = 1;
    16. minnum = min(num[i], minnum);
    17. }
    18. else { //偶数
    19. flgeven = 1;
    20. minnum = min(num[i], minnum);
    21. }
    22. }
    23. if (flgodd == 1&& flgeven == 1) {
    24. if (minnum % 2 == 0) {
    25. printf("NO\n");
    26. }else printf("YES\n");
    27. }
    28. else printf("YES\n");
    29. return;
    30. }
    31. int main() {
    32. int t;
    33. scanf("%d", &t);
    34. while (t--) Solve();
    35. return 0;
    36. }

    遇到的错误:全奇全偶的判断使用两个flg标记来实现,应该有更简单的办法。

  • 相关阅读:
    vue3基础学习
    HTML5-CSS3
    编程时不知道怎么给函数起一个好名字时怎么办
    生产者消费者模型
    SDWAN:直接互联网接入 (DIA)
    Java面试题(24)-单例模式的几种写法
    Spire.PDF for .NET【文档操作】演示:更改 PDF 版本
    bean的生命周期
    高级开发要会高效Java
    专业韩语论文翻译,论文中译韩哪里比较专业?
  • 原文地址:https://blog.csdn.net/qq_42968782/article/details/130902512