码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C语言每日一题(14):有序序列判断


    题目链接

    1.题目描述

    描述

    输入一个整数序列,判断是否是有序序列,有序,指序列中的整数从小到大排序或者从大到小排序(相同元素也视为有序)。

    数据范围: 3≤n≤50  序列中的值都满足 1≤val≤100 

    输入描述:

    第一行输入一个整数N(3≤N≤50)。

    第二行输入N个整数,用空格分隔N个整数。

    输出描述:

    输出为一行,如果序列有序输出sorted,否则输出unsorted。

    2.思路分析

    方法1 做差法

    根据当前元素的值与下一个数的差进行判断,如果大于0就是升序,小于0就是降序,这里用一个计数器来比较成功的次数,只有当次数==n-1才能判定位sorted,否则就不是。

    1. int main()
    2. {
    3. int n=0;
    4. int cn1=0;
    5. int cn2=0;
    6. scanf("%d",&n);
    7. int arr[50]={0};
    8. for(int i=0;i<n;i++)
    9. {
    10. scanf("%d",&arr[i]);
    11. }
    12. for(int i=0;i<n-1;i++)
    13. {
    14. if(arr[i]-arr[i+1]>=0)//降序判断
    15. {
    16. cn1+=1;
    17. }
    18. else if(arr[i]-arr[i+1]<=0)//升序判断
    19. {
    20. cn2+=1;
    21. }
    22. }
    23. if(cn1==n-1||cn2==n-1)//两者满足其一就是有序的
    24. {
    25. printf("sorted\n");
    26. }
    27. else {
    28. printf("unsorted\n");
    29. }
    30. return 0;
    31. }

    方法2 标记法

    思路是这样:用两个变量来定义序列的状态(升序或降序)初始化为0,如果当前值大于后面值,flag1就置为1,相同,如果当前值小于后面值,flag2置为1,循环结束后, 如果flag1和flag2同时为1,则在序列中既有降序出现,也有升序出现,就不是有序序列,否则,就是有序的。

    1. int main()
    2. {
    3. int n = 0;
    4. int flag1 = 0;
    5. int flag2 = 0;
    6. scanf("%d", &n);
    7. int arr[50] = { 0 };
    8. for (int i = 0; i < n; i++)
    9. {
    10. scanf("%d", &arr[i]);
    11. }
    12. for (int i = 0; i < n - 1; i++)
    13. {
    14. if (arr[i] > arr[i + 1])//降序
    15. {
    16. flag1 = 1;
    17. }
    18. else if (arr[i] < arr[i + 1])//升序
    19. {
    20. flag2 = 1;
    21. }
    22. }
    23. if (flag1&&flag2)
    24. {
    25. printf("unsorted\n");
    26. }
    27. else {
    28. printf("sorted\n");
    29. }
    30. return 0;
    31. }

  • 相关阅读:
    “1688商品评论接口:打造完美电商口碑的秘密武器!“
    ARM32开发--存储器介绍
    解决svn update 产生Node remains in conflict的报错问题
    uniapp(uncloud) 使用生态开发接口详情2(使用 schema创建数据, schema2code创建页面, iconfont 引入项目)
    Android Framework 常见解决方案(21)默认开启adb
    【mediasoup】TransportCongestionControlClient 1: 代码走读
    【百战GAN】SRGAN人脸低分辨率老照片修复代码实战
    vue3响应式系统
    00、数组及字符串常用的 API(详细剖析)
    Docker基于Minio搭建对象(文件)存储服务
  • 原文地址:https://blog.csdn.net/wcl312/article/details/133906933
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号