HDU_5057_分块
http://acm.hdu.edu.cn/showproblem.php?pid=5057
分块,保存每个块中每位对应数字的和,复杂的是getmum,左右下标所在的块不能直接读取block数组,要重新自己计算。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std; int a[],belong[],L[],R[],block[][][],n,m;
int ten[] = {,,,,,,,,,,}; void build()
{
int sizee = sqrt(n);
int num = n/sizee;
if(n%sizee) num++;
for(int i = ;i <= num;i++)
{
L[i] = (i-)*sizee+;
R[i] = i*sizee;
}
for(int i = ;i <= n;i++) belong[i] = (i-)/sizee+;
for(int i = ;i <= n;i++)
{
int temp = a[i];
for(int j = ;j <= ;j++)
{
block[belong[i]][j][temp%]++;
temp /= ;
}
}
} int getnum(int l,int r,int d,int p)
{
int ans = ;
if(belong[l] == belong[r])
{
for(int i = l;i <= r;i++)
{
if((a[i]/ten[d])% == p) ans++;
}
return ans;
} for(int i = belong[l]+;i < belong[r];i++) ans += block[i][d][p];
for(int i = l;i <= R[belong[l]];i++)
{
if((a[i]/ten[d])% == p) ans++;
}
for(int i = L[belong[r]];i <= r;i++)
{
if((a[i]/ten[d])% == p) ans++;
}
return ans;
} void update(int x,int y)
{
for(int i = ;i <= ;i++)
{
block[belong[x]][i][a[x]%]--;
a[x] /= ;
}
a[x] = y;
for(int i = ;i <= ;i++)
{
block[belong[x]][i][y%]++;
y /= ;
}
} int main()
{
int T;
scanf("%d",&T);
while(T--)
{
memset(block,,sizeof(block));
scanf("%d%d",&n,&m);
for(int i = ;i <= n;i++) scanf("%d",&a[i]);
build();
char s[];
while(m--)
{
scanf("%s",s);
if(s[] == 'S')
{
int x,y;
scanf("%d%d",&x,&y);
update(x,y);
}
else
{
int l,r,d,p;
scanf("%d%d%d%d",&l,&r,&d,&p);
printf("%d\n",getnum(l,r,d,p));
}
}
}
return ;
}
HDU_5057_分块的更多相关文章
- PHP搭建大文件切割分块上传功能
背景 在网站开发中,文件上传是很常见的一个功能.相信很多人都会遇到这种情况,想传一个文件上去,然后网页提示"该文件过大".因为一般情况下,我们都需要对上传的文件大小做限制,防止出现 ...
- POJ2104 K-th Number [分块做法]
传送:主席树做法http://www.cnblogs.com/candy99/p/6160704.html 做那倒带修改的主席树时就发现分块可以做,然后就试了试 思想和教主的魔法差不多,只不过那个是求 ...
- HDU 4467 分块
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4467 题意:给定n个点m条边的无向图,点被染色(黑0/白1),边带边权.然后q个询问.询问分为两种: ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1010 Weak Pair dfs序+分块
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Submissio ...
- CC countari & 分块+FFT
题意: 求一个序列中顺序的长度为3的等差数列. SOL: 对于这种计数问题都是用个数的卷积来进行统计.然而对于这个题有顺序的限制,不好直接统计,于是竟然可以分块?惊为天人... 考虑分块以后的序列: ...
- bzoj2002弹(dan)飞绵羊 分块水过
据说是道lct求深度的题 但是在小猫大的指点下用分块就n^1.5水过了 = =数据忘记加强系列 代码极其不美观,原因是一开始是听小猫大讲的题意,还以为是弹到最前面... #include <cs ...
- C语言两种查找方式(分块查找,二分法)
二分法(必须要保证数据是有序排列的): 分块查找(数据有如下特点:块间有序,块内无序):
- [New Portal]Windows Azure Storage (14) 使用Azure Blob的PutBlock方法,实现文件的分块、离线上传
<Windows Azure Platform 系列文章目录> 相关内容 Windows Azure Platform (二十二) Windows Azure Storage Servic ...
- BZOJ 3343: 教主的魔法 [分块]【学习笔记】
3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1172 Solved: 526[Submit][Status][Discus ...
随机推荐
- Jquery实现图片管理
这里实现的是一个图片的在线管理,类似于网络相册的图片管理. 效果图如下: 文件结构如下图: style2.css文件内容如下: @charset "utf-8"; *{;; } i ...
- java类中元素初始化顺序
结论:对于静态变量.静态初始化块.变量.初始化块.构造器,它们的初始化顺序依次是(静态变量.静态初始化块)>(变量.初始化块)>构造器. public class Test4 { @Tes ...
- python爬虫——selenium+chrome使用代理
先看下本文中的知识点: python selenium库安装 chrome webdirver的下载安装 selenium+chrome使用代理 进阶学习 搭建开发环境: selenium库 chro ...
- 【译】如何使用Vue过渡效果来提升用户体验
在Vue应用中添加过渡效果是一个可以使你的项目感觉更专业的简单方法.通过提升用户体验,可以使你的网站留住更多的用户以及提高转化率. 只需要简单的处理就可以获得巨大的回报,何乐而不为? 在这个指南中,我 ...
- python-review01
# 1.使用while循环输出 1 2 3 4 5 6 8 9 10 count = 0 while count < 10: count += 1 if count == 7: continue ...
- vue-cookies
vue-cookies用于登录,一般和vuex一起使用 vuex在各个组件共享值,cookie恒久保留值 一.安装 npm install vue-cookies --save 二.引用(在store ...
- 如何在匿名thread子类中保证线程安全
在做性能测试的过程中,我写了两个虚拟类ThreadLimitTimeCount和ThreadLimitTimesCount做框架,通过对线程的标记来完成超时请求的记录.旧方法如下: @Override ...
- Asp.Net Core 3.1 Api 集成Abp项目依赖注入
Abp 框架 地址https://aspnetboilerplate.com/ 我们下面来看如何在自己的项目中集成abp的功能 我们新建core 3.1 API项目和一个core类库 然后 两个项目都 ...
- [洛谷P3254] [网络流24题] 圆桌游戏
Description 假设有来自m 个不同单位的代表参加一次国际会议.每个单位的代表数分别为ri (i =1,2,--,m). 会议餐厅共有n 张餐桌,每张餐桌可容纳ci (i =1,2,--,n) ...
- 第二阶段冲刺个人任务——five
今日任务: 合并程序(统计团队博客). 昨日成果: 优化统计团队博客结果界面的显示.