BestCoder Round #65 C. ZYB's Premutation(线段树求第k大)

题意:

[1,i],

分析:

,,,线k,BIT

代码:

//
//  Created by TaoSama on 2015-12-05
//  Copyright (c) 2015 TaoSama. All rights reserved.
//
//#pragma comment(linker, "/STACK:1024000000,1024000000")
#include <algorithm>
#include <cctype>
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iomanip>
#include <iostream>
#include <map>
#include <queue>
#include <string>
#include <set>
#include <vector>

using namespace std;
#define pr(x) cout << #x << " = " << x << "  "
#define prln(x) cout << #x << " = " << x << endl
const int N = 1e5 + 10, INF = 0x3f3f3f3f, MOD = 1e9 + 7;

int n, a[N];

int sum[N << 2], ans[N];

void build(int l, int r, int rt) {
    sum[rt] = r - l + 1;
    if(l == r) return;
    int m = l + r >> 1;
    build(l, m, rt << 1);
    build(m + 1, r, rt << 1 | 1);
}

int query(int k, int l, int r, int rt) {
    --sum[rt];
    if(l == r) return l;
    int m = l + r >> 1;
    if(k >= sum[rt << 1 | 1]) return query(k - sum[rt << 1 | 1], l, m, rt << 1);
    else return query(k, m + 1, r, rt << 1 | 1);
}

int main() {
#ifdef LOCAL
    freopen("C:\\Users\\TaoSama\\Desktop\\in.txt", "r", stdin);
//  freopen("C:\\Users\\TaoSama\\Desktop\\out.txt","w",stdout);
#endif
    ios_base::sync_with_stdio(0);

    int t; scanf("%d", &t);
    while(t--) {
        scanf("%d", &n);
        for(int i = 1; i <= n; ++i) scanf("%d", a + i);

        build(1, n, 1);
        int all = n;
        for(int i = n; i; --i) {
            int k = a[i] - a[i - 1];
            ans[i] = query(k, 1, n, 1);
        }
        for(int i = 1; i <= n; ++i)
            printf("%d%c", ans[i], " \n"[i == n]);
    }
    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误提示[Errno 13] Permission denied意味着你正在尝试执行一个文件,但是当前用户没有执行该文件的权限。这可能是由于文件系统权限设置不正确导致的。 你可以按照以下步骤来解决这个问题: 1. 首先,检查你要执行的文件的权限。确保该文件对运行该命令的用户有执行权限。你可以使用chmod命令来更改文件的权限。 2. 如果你无法更改文件的权限,那么可能是因为你没有足够的权限来更改文件的权限。在这种情况下,你可以尝试使用管理员权限运行命令,或者联系系统管理员来更改文件的权限。 3. 另外,还有一种可能是你正在尝试执行一个exe文件,但是该文件不是可执行文件。这可能是由于文件损坏或错误的文件类型导致的。在这种情况下,你可以尝试重新下载或生成可执行文件,并确保它是正确的文件类型。 引用: pyinstaller 安装报错 pyinstaller PermissionError: [Errno 13] Permission denied: 'C:\\Users\\ZHAN\\Desktop\\build\\data2pic1\\data2pic1.exe.notanexecutable' 引用: 在使用pyinstaller打包成exe文件时,如果出现下面的问题: [pyinstaller]PermissionError: [Errno 13] Permission denied:C:\Users\xxx\AppData\Local\ucrtbase.dll 引用: Check the file system permissions of the file you are trying to execute. Make sure the file has execute permission for the user running the command. You can use the chmod command to change the file permissions. 所以,[Errno 13] Permission denied: 'C:\\Users\\hanme'错误提示意味着你尝试执行的文件'C:\\Users\\hanme'没有执行权限。你可以通过更改该文件的权限来解决这个问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [pyinstaller PermissionError: [Errno 13] Permission denied:](https://blog.csdn.net/weixin_46604505/article/details/131254346)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [[pyinstaller]PermissionError: [Errno 13] Permission denied:C:\Users\xxx\AppData\Local\ucrtbase.dll](https://blog.csdn.net/zyb228107/article/details/119698819)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值