码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 排序 (爱思创算法四)(期中测试)(答案记录)


    前言:

    这篇文章还是是为了帮助一些

    像我这样的菜鸟

    找到简单的题解

    题目描述

    小思老师现在拿到了一个数字序列,

    这个数字序列恰好由1到n这n个数字组成,

    但这些数字可能没有排序。

    由于小思老师平时工作比较忙,

    她每次只能针对这n个数的一个子区间进行排序,

    比如:给定一个区间[l, r],将这个区间从小到大排序,需要花费r-l+1个精力。

    现在小思老师可以执行若干次这样的操作,

    直到这个序列中所有的数字从1到n升序排列。

    小思老师想知道,她需要花费的精力最少是多少?

    输入描述

    本题有多组询问,第一行有一个数T表示询问组数。

    对于每组询问:

    第一行给出一个整数n

    第二行n个整数,由空格隔开,代表待排序的序列。

    输出描述

    T行,每行一个整数表示一组询问的答案。

    输入样例#1

    1. 2
    2. 3
    3. 1 3 2
    4. 4
    5. 3 2 1 4

    输出样例#1

    1. 2
    2. 3

    提示

    对于30%的数据,T组中所有n的累加和 <= 5000

    对于100%的数据,T组中所有n的累加和 <= 100000 1<=T<=100000

    本题线下文件测评时的说明:

    - 可执行文件名:sort

    - 提交源程序文件名:sort.cpp

    - 输入文件名:sort.in

    - 输出文件名:sort.out

    - 时间限制:1秒

    - 空间限制:256MB

    完整代码:

    1. #include
    2. using namespace std;
    3. const int N = 1e5+5;
    4. int a[N],b[N];
    5. int n;
    6. int main()
    7. {
    8. //freopen("sort.in","r",stdin);
    9. //freopen("sort.out","w",stdout);
    10. int t;
    11. cin>>t;
    12. while(t--)
    13. {
    14. memset(b,0,sizeof(b));
    15. cin>>n;
    16. for(int i=1;i<=n;i++)
    17. {
    18. cin>>a[i];
    19. }
    20. int ans=0;
    21. for(int i=1;i<=n;i++)
    22. {
    23. if(a[i]>i)
    24. {
    25. b[i]++;
    26. b[a[i]+1]--;
    27. }
    28. }
    29. for(int i=1;i<=n;i++)
    30. {
    31. a[i]=a[i-1]+b[i];
    32. if(a[i]) ans++;
    33. }
    34. cout<
    35. }
    36. return 0;
    37. }

    AC

  • 相关阅读:
    详解GMM高斯混合模型EM模型
    2022-08-20 mysql范围查询技术专利交底书
    Enzo大肠杆菌宿主细胞蛋白ELISA试剂盒——3小时内出结果!
    docker搭建minio服务器,解决内网穿透后外网无法访问问题
    EasyCVR新增角色分配分组功能的使用及注意事项
    Containerd高级命令行工具nerdctl安装及使用
    后端程序员入门react笔记(五)ajax请求
    Go函数并发情况的错误处理
    【FPGA教程案例35】通信案例5——基于FPGA的16QAM调制信号产生,通过matlab测试其星座图
    myBatis基础学习笔记
  • 原文地址:https://blog.csdn.net/HackerQY/article/details/127817720
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号