题解 | #【模板】线段树1#

【模板】线段树1

https://www.nowcoder.com/practice/e767b7b441ce4345aad1fac0a3633afb

import java.io.*;
import java.util.*;
import java.math.BigInteger;

public class Main {
    static int N = (int)(1e5+10);
    static int n,q;
    static long[] a = new long[N],c = new long[N];

    static int lowbit(int x) {
        return x & -x;
    }

    static void add(int x,long v) {
        for(int i=x;i<=n;i+=lowbit(i)) {
            c[i] += v;
        }
    }

    static long sum(int x) {
        long res = 0;
        for(int i=x;i>0;i-=lowbit(i)) {
            res += c[i];
        }
        return res;
    }

    static void solve() {
        n=in.nextInt(); q = in.nextInt();
        for(int i=1;i<=n;i++) {
            a[i] = in.nextLong();
            add(i,a[i]);
        }
        while(q-->0) {
            int op = in.nextInt();
            if(op==1) {
                int i = in.nextInt(), k = in.nextInt();
                add(i,k);
            }else {
                int l = in.nextInt(), r = in.nextInt();
                out.println(sum(r)-sum(l-1));
            }
        }
    }

    public static void main(String[] args) {
        solve();
        out.flush();
    }
 
    static FastReader in = new FastReader();
    static PrintWriter out = new PrintWriter(System.out);

    static class FastReader {
        static BufferedReader br;
        static StringTokenizer st;

        FastReader() {
            br = new BufferedReader(new InputStreamReader(System.in));
        }

        String next() {
            String str = "";
            while(st==null||!st.hasMoreElements()) {
                try {
                    str = br.readLine();
                }catch(IOException e) {
                    throw new RuntimeException(e);
                }
                st = new StringTokenizer(str);
            }
            return st.nextToken();
        }

        int nextInt() {
            return Integer.parseInt(next());
        }

        double nextDouble() {
            return Double.parseDouble(next());
        }

        long nextLong() {
            return Long.parseLong(next());
        }
    }
}

全部评论

相关推荐

昨天 15:12
门头沟学院 Java
别人在上班,我就在工位上看看视频啥的,这正常吗?
程序员小白条:实习就是摸鱼,只是公司指标,把你进来了,可能那时候客户很多,但等你进来的时候,已经是淡季了,根本没多少需求,或者说根本不适合实习生去完成,因此你就每天干坐着就行,可能1,2个月都没需求
实习生的蛐蛐区
点赞 评论 收藏
分享
来个大佬救一下,为上投了都是石沉大海了,没实习经历的话怕秋招直接进不了面。什么实习这么难找,基本
心态爆炸了:现在正式的岗位都少,实习基本不咋招的,除了大厂,中小企业其实没那么多岗位需求,就算是有,大多都是招一两个廉价劳动力,同时,他们也会希望你一来就能干活的,没时间培训你,就让你了解公司的项目,你了解完就可以开始干活。再者是,很多低质量的实习其实用处没有那么大的。我去年也是找实习找到破防,最后去了一家深圳的小公司实习,工作对我来说很简单,甚至不如我在学校做的项目,秋招的时候,这段实习经历也并没有帮上什么忙,投递简历,依旧非常低的回复率。低回复率是常态,尤其是找实习,找不到,那就把重心放在优化自己的简历和项目,多看八股文,锻炼自己的面试能力,多看别人的面经,自己模拟面试,等秋招的时候,只要有那么寥寥几次,好好抓住那几次机会。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务