codves 4919 线段树练习4「建议收藏」

codves 4919 线段树练习4

大家好,又见面了,我是全栈君。

 时间限制: 1 s

 空间限制: 128000 KB

 题目等级 : 黄金 Gold

题目描述 Description

给你N个数,有两种操作

1:给区间[a,b]内的所有数都增加X

2:询问区间[a,b]能被7整除的个数

输入描述 Input Description

第一行一个正整数n,接下来n行n个整数,再接下来一个正整数Q,表示操作的个数. 接下来Q行每行若干个整数。如果第一个数是add,后接3个正整数a,b,X,表示在区间[a,b]内每个数增加X,如果是count,表示统计区间[a,b]能被7整除的个数

输出描述 Output Description

对于每个询问输出一行一个答案

样例输入 Sample Input

   

3 
2 3 4
6
count 1 3
count 1 2
add 1 3 2
count 1 3
add 1 3 3
count 1 3

 

样例输出 Sample Output

0

0

0

1

数据范围及提示 Data Size & Hint

10%:1<N<=10,1<Q<=10

30%:1<N<=10000,1<Q<=10000

100%:1<N<=100000,1<Q<=100000

codves 4919 线段树练习4「建议收藏」codves 4919 线段树练习4「建议收藏」

#include<cstdio>
#include<cstring>
using namespace std;
const int N=100010;
struct node
{
    int lazy,l,r;
    int sum[8];
}tr[N<<2];
int arr[10];
inline void pushup(int ro)
{
    for(int i=0;i<=6;i++) tr[ro].sum[i]=tr[ro<<1].sum[i]+tr[ro<<1|1].sum[i];    
}
void build(int ro,int l,int r)
{
    tr[ro].l=l,tr[ro].r=r;
    if(l==r)
    {
        int a;
        scanf("%d",&a);
        tr[ro].sum[a%7]++;
    }
    else
    {
        int mid=(l+r)>>1;
        build(ro<<1,l,mid);
        build(ro<<1|1,mid+1,r);
        pushup(ro);
    }
    return;
}
inline void down(int ro)
{
    tr[ro<<1].lazy+=tr[ro].lazy;
    tr[ro<<1|1].lazy+=tr[ro].lazy;
    for(int i=0;i<=6;i++) arr[i]=0,arr[i]=tr[ro<<1].sum[i];
    for(int i=0;i<=6;i++) tr[ro<<1].sum[(i+tr[ro].lazy)%7]=arr[i];
    for(int i=0;i<=6;i++) arr[i]=0,arr[i]=tr[ro<<1|1].sum[i];
    for(int i=0;i<=6;i++) tr[ro<<1|1].sum[(i+tr[ro].lazy)%7]=arr[i];
    tr[ro].lazy=0;
}
void change(int ro,int l,int r,int add)
{
    if(l<=tr[ro].l&&tr[ro].r<=r)
    {
        for(int i=0;i<=6;i++) arr[i]=0,arr[i]=tr[ro].sum[i];
        for(int i=0;i<=6;i++) tr[ro].sum[(i+add)%7]=arr[i];
        //printf("%d\n",add);
        tr[ro].lazy+=add;
        tr[ro].lazy%=7;
        //for(int i=1;i<=20;i++) {for(int j=0;j<=6;j++) printf("%d ",tr[i].sum[j]);printf("%d %d\n",tr[i].l,tr[i].r);}
        return;
    }
    if(tr[ro].lazy) down(ro);
    int mid=(tr[ro].l+tr[ro].r)>>1;
    if(l<=mid) change(ro<<1,l,r,add);
    if(mid<r)  change(ro<<1|1,l,r,add);
    pushup(ro);
    return;
}
long long int query(int ro,int l,int r)
{
    if(l<=tr[ro].l&&tr[ro].r<=r) return tr[ro].sum[0];
    if(tr[ro].lazy) down(ro);
    long long int ans=0;
    int mid=(tr[ro].l+tr[ro].r)>>1;
    if(l<=mid)  ans+=query(ro<<1,l,r);
    if(r>mid)   ans+=query(ro<<1|1,l,r);
    return ans;
}
int main()
{
    int n;
    scanf("%d",&n);
    build(1,1,n);
    //for(int i=1;i<=20;i++) {for(int j=0;j<=6;j++) printf("%d ",tr[i].sum[j]);printf("%d %d\n",tr[i].l,tr[i].r);}
    int m;
    scanf("%d",&m);
    for(int i=1;i<=m;i++)
    {
        char pd[8];
        scanf("%s",pd);
        if(pd[0]=='a')
        {
            int a,b,x;
            scanf("%d %d %d",&a,&b,&x);
            change(1,a,b,x%7);
            //for(int k=1;k<=20;k++) {for(int j=0;j<=6;j++) printf("%d ",tr[k].sum[j]);printf("%d %d\n",tr[k].l,tr[k].r);}
        }
        else
        {
            int l,r;
            scanf("%d %d",&l,&r);
            printf("%lld\n",query(1,l,r));
        }
    }
    return 0;    
}

View Code

关键是我们需要维护的东西是什么?

我们用一个数组存区间内%7后每个值的个数;

最后输出值为0的个数。

转载于:https://www.cnblogs.com/12fs/p/7457535.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108201.html原文链接:https://javaforall.net

(0)
上一篇 2022年3月6日 下午5:00
下一篇 2022年3月6日 下午6:00


相关推荐

  • idea git 使用(idea开发工具怎么使用)

    简介以下会介绍Git在IDEA中的使用,包含大多数的开发场景,这里是用Github做远程仓库,假设小组中有两个人,队长A,和队员B场景一:队长A创建项目并提交到远程Git仓库场景二:队员B从远程Git仓库上获取项目源码场景三:队员B修改了部分源码,提交到远程仓库场景四:队长A从远程仓库获取队员B的提交场景五:队员B接受了一个新功能的任务,创建了一个分支并在分支上开发场景六:队员B把…

    2022年4月17日
    55
  • TTL与RS-232电平转换芯片MAX232/MAX3232「建议收藏」

    TTL与RS-232电平转换芯片MAX232/MAX3232「建议收藏」TTL电平标准:输出L:2.4V             输入L:2.0V RS-232标准:逻辑1的电平为-3~-15V,逻辑0的电平为+3~+15V    MAX232供电电压只能是5V的,也就是说对于3.3V的系统,最好采用宽电压的MAX3232,电压范围3V~5V,而管脚是兼容的,只是电容的选取有所不同。 电容的选取如下:

    2022年8月10日
    12
  • aaa服务器显示认证失败,华为aaa认证案例-电信华为机顶盒50%通路故障或AAA认证失败怎么回…

    aaa服务器显示认证失败,华为aaa认证案例-电信华为机顶盒50%通路故障或AAA认证失败怎么回…华为交换机AAA配置与管理内容来自用户:wanhyl一、基础1、AAA是指:authentication(认证)、authorization(授权)、accounting(计费)的简称,是网络安全的一种管理机制;Authentication是本地认证/授权,authorization和accounting是由远处radius(远程拨号认证系统)服务或hwtacacs(华为终端访问控制系统)服务器完…

    2022年5月4日
    558
  • 有极性电容和无极性电容的区别_非极性电容

    有极性电容和无极性电容的区别_非极性电容有极性电容与无极性电容的概述有极性电容与无极性电容的概述有极性电容的识别有极性电容于无极性电容的区别网友见解有极性电容与无极性电容的概述理想的电容,本来是没有极性的。但是在实际中,为了获得大容量,就使用了某些特殊的材料和结构,这就导致了实际的电容有些是有极性的。常见的有极性电容有铝电解电容,钽电解电容等。电解电容一般是容量相对比较大的。如果要做一个大容量的无极性电容,就没那…

    2022年8月22日
    13
  • Redis 6379端口无法telnet登陆

    Redis 6379端口无法telnet登陆一、现象:Redis所在服务器无法telnet 二、问题原因  redis-server默认开放的127.0.0.1IP地址需要修改为0.0.0.0才可以被其他机器访问三、解决办法(Windows)  1,在Redis安装目录下找到配置文件 redis.windows.config  2,修改bind127.0.0.1改为bind0.0.0.0    3,重启Redis…

    2022年5月2日
    121
  • 深度解析DeepSeek使用教程:从入门到精通

    深度解析DeepSeek使用教程:从入门到精通

    2026年3月16日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号