AT_arc110_c序列, 题目详解

更好的阅读体验:

  • link , 点击这里喵

题目链接:

  • link , 点击这里喵

题意简述:

  • 给出一个排列, 长度为 n n n 问是否能通过 n − 1 n-1 n1 次交换 (第 i i i 位有且仅可以与 i + 1 i+1 i+1 位交换一次), 使这个排列递增. (必须交换 n − 1 n-1 n1 次)

思路:

  • 能使用一次, 这意味着如果右边有一个数在这个位置的左边, 那么通过这仅有一次机会
  • 如果这一个机会被占用了, 那么这个数就不能归位了喵 …

做法:

  • 所以, 应当使当前未归位最小数先归位, 否则左边的交换会阻止其到达, 右边的交换则对此无影响
  • 定义一个变量 u s e use use 为使用过的侧边界,若当前要归位的数在 u s e use use 左边,说明已经使用过, 则不可行
if(i<=use && date[i]!=i){
   puts("-1");          
   return 0;            
}             
  • 持续这样操作,直到所有数归位
for(int i=1;i<=n;++i){
   if(i<=use && date[i]!=i){
       puts("-1");
       return 0;
   }
   use=zb[i]-1;
   for(int e=use;e>=i;--e){
       swap(date[e],date[e+1]);
       zb[date[e]]=e;
       zb[date[e+1]]=e+1;
       ans.push_back(e);
   }
}
  • 当结束循环后, 查看是否使用了 n − 1 n-1 n1 次.
if((int)ans.size()!=n-1){puts("-1");return 0;}

小贴士:

  • 上述代码中使用了 z b zb zb 数组来存储每个数的位置, 而 d a t e date date 数组则是存每个位置是什么数, 记得两个都要更新喵
  • 这里使用了 v e c o t r vecotr vecotr 来存储答案, 蒟蒻认为这样简单一些

时间复杂度分析

  • 由于 u s e use use 每个点只能有一次, 而 u s e use use 单调不降, 最多对 u s e use use 进行 n n n 次操作, 故时间复杂度为 O ( n ) O(n) O(n)

代码:

#include <stdio.h>
#include <ctype.h>
#include <algorithm>
#include <vector>
#define lnt long long
using namespace std;
int xx;char ff,chh;inline int read(){
    xx=ff=0;while(!isdigit(chh)){if(chh=='-'){ff=1;}chh=getchar();}
    while(isdigit(chh)){xx=(xx<<1)+(xx<<3)+chh-'0';chh=getchar();}return ff? -xx: xx;
}
const int N=1e6;
int n,use,date[N],zb[N];
vector<int> ans;
int main(){
    n=read();
    for(int i=1;i<=n;++i){
        date[i]=read();
        zb[date[i]]=i;
    }
    for(int i=1;i<=n;++i){
        if(i<=use && date[i]!=i){
            puts("-1");
            return 0;
        }
        use=zb[i]-1;
        for(int e=use;e>=i;--e){
            swap(date[e],date[e+1]);
            zb[date[e]]=e;
            zb[date[e+1]]=e+1;
            ans.push_back(e);
        }
    }
    if((int)ans.size()!=n-1){puts("-1");return 0;}
    for(auto i: ans){printf("%d\n",i);}
    return 0;
}
  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
lv_arc_set_bg_angles函数是用来设置Arc控件的背景角度的。通过该函数可以指定Arc控件的背景起始角度和结束角度。\[1\]例如,可以使用lv_arc_set_bg_angles(arc, start_angle, end_angle)来设置Arc控件的背景角度范围。其中,arcArc控件的指针,start_angle是背景起始角度,end_angle是背景结束角度。\[1\] 下面是一个使用lv_arc_set_bg_angles函数的示例代码: ```c void lvgl_arc_angle_test(void) { /* 创建一个Arc控件 */ lv_obj_t* arc = lv_arc_create(lv_scr_act(), NULL); /* 设置背景角度范围 */ lv_arc_set_bg_angles(arc, 180, 360); /* 设置Arc控件的角度范围 */ lv_arc_set_angles(arc, 180, 270); /* 设置Arc控件的大小 */ lv_obj_set_size(arc, 200, 200); /* 将Arc控件居中对齐 */ lv_obj_align(arc, NULL, LV_ALIGN_CENTER, 0, 0); } ``` 在上述示例代码中,我们创建了一个Arc控件,并使用lv_arc_set_bg_angles函数设置了背景角度范围为180度到360度。\[2\]这样,Arc控件的背景将会从180度开始绘制,一直绘制到360度。 #### 引用[.reference_title] - *1* *2* *3* [用GUI画个弧?走起!LVGL『Arc弧控件』介绍走起](https://blog.csdn.net/XiaoXiaoPengBo/article/details/113869980)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值