BC96 有序序列判断

描述

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

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

输入描述

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

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

输出描述

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

代码:

复制代码
#include <stdio.h>

int main() 
{
    int n=0;
    scanf("%d",&n);
    int arr[50]={0};
    int i=0;
    int flag1=0;//升序
    int flag2=0;//降序
    for(i=0;i<n;i++)
    {
        scanf("%d",&arr[i]);
        if(i>0)
        {
            if(arr[i]>arr[i-1])
            {
                flag1=1;//如果为降序,flag1一直为0
            }
            else
            {
                flag2=1;//如果为升序,flag2一直为0
            }
        }
    }
    if(flag1+flag2 == 1)
    {
        printf("sorted\n");
    }
    if(flag1+flag2 == 2)//如果数组元素一会升序一会降序,南无flag1和flag2都是1
    {
        printf("unsorted\n");
    }
    
    return 0;
}

代码思路:设置升序flag1=0和降序flag2=0,如果为数组升序,则只有flag1被置1;如果数组为降序,则只有flag2被置1。因此,如果数组有序,那么flag1+flag2=1,否则flag1+flag2=2。

相关推荐
TracyCoder1234 分钟前
LeetCode Hot100(3/100)——128.最长连续序列
算法·leetcode
Piar1231sdafa25 分钟前
【目标检测】竹林与杂草识别_YOLOv26改进算法研究
算法·yolo·目标检测
EmbedLinX28 分钟前
一文理解后端核心概念:同步/异步、阻塞/非阻塞、进程/线程/协程
linux·服务器·c语言·网络
风筝在晴天搁浅28 分钟前
hot100 543.二叉树的直径
算法·深度优先
风筝在晴天搁浅31 分钟前
hot100 102.二叉树的层序遍历
java·算法
张祥64228890434 分钟前
误差理论与测量平差基础笔记八
笔记·算法·机器学习
进击的小头34 分钟前
传递函数与系统特性(核心数学工具)
python·算法·数学建模
清酒难咽34 分钟前
算法案例之回溯法
c++·经验分享·算法
程序员-King.34 分钟前
day168—递归—二叉树的最大路径和(LeetCode-124)
算法·leetcode·深度优先·递归
源代码•宸36 分钟前
Leetcode—513. 找树左下角的值【中等】
经验分享·算法·leetcode·面试·职场和发展·golang·dfs