码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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标记来实现,应该有更简单的办法。

  • 相关阅读:
    在T3开发板上实现SylixOS最小系统(四)——实现调试调试信息打印接口
    数据库管理-第四十一期 一堆问题(20221029)
    web网页设计—— 指环王:护戒使者(13页) 电影网页设计 在线电影制作 个人设计web前端大作业
    slam学习 - 基本VO代码学习
    Buuctf [极客大挑战 2019]BuyFlag1 WP解析
    基于安卓android微信小程序音乐播放器
    【nodejs】express-generator项目--创建接口及数据库连接
    iOS视图控件的内容显示和离屏渲染流程
    免费开箱即用的微鳄任务管理系统
    python的深浅copy
  • 原文地址:https://blog.csdn.net/qq_42968782/article/details/130902512
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号