\(\text{Solution}\)

首先把 \(T2\) 给切了,\(T1\) 找半天规律找不到

然后打了个表算是暴力了

\(T3\) 也暴。。。

太暴了。。。

\(T4\) 直接啥也不会

\(\text{T1}\)

考虑一个 \(a\) 的答案

\((c+b)(c-b)=a^2\) 或 \((c+b)(c-b)=(a+1)(a-1)\) 的 \(c,b\) 组数

就是一般的分类讨论了,记一个数 \(a\) 的答案为 \(f(a)\),\(d(a)\) 为 \(a\) 的约数个数

那么 \(2\nmid a,f(a)=d(a)/2\)

\(4\mid a,f(a)=d(a/4)/2\)

其余则为 \(0\)

具体考虑 \(a^2\) 和 \(a^2-1\) 的 \(f\) 值即可

\(\text{Code}\)

#include <cstdio>
#define RE register
using namespace std;
typedef long long LL; const int N = 1e7 + 5;
int x, y, d[N], _d[N], num[N], tot, pr[N / 10], vis[N], ans; void Sieve()
{
d[1] = _d[1] = num[1] = 1;
for(RE int i = 2; i <= 1e7 + 3; i++)
{
if (!vis[i]) pr[++tot] = i, d[i] = 2, num[i] = 1, _d[i] = 3;
for(RE int j = 1, z; j <= tot && pr[j] * i <= 1e7 + 3; j++)
{
vis[z = i * pr[j]] = 1;
if (i % pr[j] == 0)
{
num[z] = num[i] + 1, d[z] = d[i] / num[z] * (num[z] + 1);
_d[z] = _d[i] / (num[i] * 2 + 1) * (num[z] * 2 + 1);
break;
}
else d[z] = d[i] * 2, num[z] = 1, _d[z] = _d[i] * 3;
}
}
} int main()
{
Sieve(), scanf("%d%d", &x, &y);
for(RE int a = x; a <= y; a++)
if (a & 1) ans += (LL)_d[a] / 2 + (LL)d[(a + 1) / 2] * d[(a - 1) / 2] / 2;
else ans += (LL)d[a + 1] * d[a - 1] / 2 + _d[a / 2] / 2;
printf("%d\n", ans);
}

\(\text{T2}\)

一眼分位变成线段树赋值和异或操作

\(\text{Code}\)

#include <cstdio>
#define RE register
#define IN inline
using namespace std; const int N = 5e4 + 5, LG = 9, SZ = N * 4, M = LG + 2;
int n, m, a[N]; struct SegmenTree{
#define ls (p << 1)
#define rs (ls | 1)
int sum[SZ][M], tg1[SZ][M], tg2[SZ][M];
IN void pushup(int p, int k){sum[p][k] = sum[ls][k] + sum[rs][k];}
void build(int p, int l, int r)
{
for(RE int j = 0; j <= LG; j++) tg1[p][j] = -1;
if (l == r)
{
for(RE int j = 0; j <= LG; j++) sum[p][j] = ((a[l] >> j) & 1);
return;
}
int mid = l + r >> 1; build(ls, l, mid), build(rs, mid + 1, r);
for(RE int j = 0; j <= LG; j++) pushup(p, j);
}
IN void push(int p, int k, int z, int l, int r)
{
if (z == 0 || z == 1) sum[p][k] = z * (r - l + 1), tg1[p][k] = z;
else{
sum[p][k] = r - l + 1 - sum[p][k], tg2[p][k] ^= 1;
if (tg1[p][k] != -1) tg1[p][k] ^= 1;
}
}
IN void pushdown(int p, int k, int l, int r)
{
int mid = l + r >> 1;
if (tg2[p][k]) push(ls, k, 2, l, mid), push(rs, k, 2, mid + 1, r), tg2[p][k] = 0;
if (tg1[p][k] != -1) push(ls, k, tg1[p][k], l, mid), push(rs, k, tg1[p][k], mid + 1, r), tg1[p][k] = -1;
}
void assign(int p, int l, int r, int k, int x, int y, int z)
{
if (x > r || y < l) return;
if (x <= l && r <= y) return push(p, k, z, l, r), void();
pushdown(p, k, l, r); int mid = l + r >> 1;
if (x <= mid) assign(ls, l, mid, k, x, y, z);
if (y > mid) assign(rs, mid + 1, r, k, x, y, z);
pushup(p, k);
}
void reverse(int p, int l, int r, int k, int x, int y)
{
if (x > r || y < l) return;
if (x <= l && r <= y) return push(p, k, 2, l, r), void();
pushdown(p, k, l, r); int mid = l + r >> 1;
if (x <= mid) reverse(ls, l, mid, k, x, y);
if (y > mid) reverse(rs, mid + 1, r, k, x, y);
pushup(p, k);
}
int Query(int p, int l, int r, int k, int x, int y)
{
if (x > r || y < l) return 0;
if (x <= l && r <= y) return sum[p][k];
pushdown(p, k, l, r); int mid = l + r >> 1, res = 0;
if (x <= mid) res = Query(ls, l, mid, k, x, y);
if (y > mid) res += Query(rs, mid + 1, r, k, x, y);
return res;
}
}T; int main()
{
scanf("%d%d", &n, &m);
for(RE int i = 1; i <= n; i++) scanf("%d", &a[i]);
T.build(1, 1, n); char op[10];
for(RE int l, r, x; m; --m)
{
scanf("%s%d%d", op, &l, &r);
if (op[0] == 'a'){
scanf("%d", &x);
for(RE int j = 0; j <= LG; j++) if (!((x >> j) & 1)) T.assign(1, 1, n, j, l, r, 0);
}
else if (op[0] == 'o'){
scanf("%d", &x);
for(RE int j = 0; j <= LG; j++) if ((x >> j) & 1) T.assign(1, 1, n, j, l, r, 1);
}
else if (op[0] == 'x'){
scanf("%d", &x);
for(RE int j = 0; j <= LG; j++) if ((x >> j) & 1) T.reverse(1, 1, n, j, l, r);
}
else if (op[1] == 'x'){
int res = 0, z;
for(RE int j = 0; j <= LG; j++) z = T.Query(1, 1, n, j, l, r), res += ((z & 1) ? (1 << j) : 0);
printf("%d\n", res);
}
else{
int res = 0, z;
for(RE int j = 0; j <= LG; j++) z = T.Query(1, 1, n, j, l, r), res += z * (1 << j);
printf("%d\n", res);
}
}
}

JZOJ 2022.02.11【提高A组】模拟的更多相关文章

  1. JZOJ 5305. 【NOIP2017提高A组模拟8.18】C (Standard IO)

    5305. [NOIP2017提高A组模拟8.18]C (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Description ...

  2. JZOJ 100029. 【NOIP2017提高A组模拟7.8】陪审团

    100029. [NOIP2017提高A组模拟7.8]陪审团 Time Limits: 1000 ms  Memory Limits: 131072 KB  Detailed Limits   Got ...

  3. JZOJ 5818. 【NOIP提高A组模拟2018.8.15】 做运动

    5818. [NOIP提高A组模拟2018.8.15] 做运动 (File IO): input:running.in output:running.out Time Limits: 2000 ms  ...

  4. JZOJ 5812. 【NOIP提高A组模拟2018.8.14】 区间

    5812. [NOIP提高A组模拟2018.8.14] 区间 (File IO): input:range.in output:range.out Time Limits: 1000 ms  Memo ...

  5. JZOJ 4732. 【NOIP2016提高A组模拟8.23】函数

    4732. [NOIP2016提高A组模拟8.23]函数 (Standard IO) Time Limits: 1500 ms  Memory Limits: 262144 KB  Detailed ...

  6. JZOJ 5328. 【NOIP2017提高A组模拟8.22】世界线

    5328. [NOIP2017提高A组模拟8.22]世界线 (File IO): input:worldline.in output:worldline.out Time Limits: 1500 m ...

  7. JZOJ 5329. 【NOIP2017提高A组模拟8.22】时间机器

    5329. [NOIP2017提高A组模拟8.22]时间机器 (File IO): input:machine.in output:machine.out Time Limits: 2000 ms M ...

  8. JZOJ 5307. 【NOIP2017提高A组模拟8.18】偷窃 (Standard IO)

    5307. [NOIP2017提高A组模拟8.18]偷窃 (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Description ...

  9. JZOJ 5286. 【NOIP2017提高A组模拟8.16】花花的森林 (Standard IO)

    5286. [NOIP2017提高A组模拟8.16]花花的森林 (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Descript ...

  10. [JZOJ]100047. 【NOIP2017提高A组模拟7.14】基因变异

    21 世纪是生物学的世纪,以遗传与进化为代表的现代生物理论越来越多的 进入了我们的视野. 如同大家所熟知的,基因是遗传因子,它记录了生命的基本构造和性能. 因此生物进化与基因的变异息息相关,考察基因变 ...

随机推荐

  1. 总算给女盆友讲明白了,如何使用stream流的filter()操作

    一.引言 在上一篇文章中<这么简单,还不会使用java8 stream流的map()方法吗?>分享了使用stream的map()方法,不知道小伙伴还有印象吗,先来回顾下要点,map()方法 ...

  2. 踩坑记录:Redis的lettuce连接池不生效

    踩坑记录:Redis的lettuce连接池不生效 一.lettuce客户端 lettuce客户端 Lettuce 和 Jedis 的都是连接Redis Server的客户端程序.Jedis在实现上是直 ...

  3. Docker容器入门到精通

    Docker 容器 快速入门 第一章:Docker容器 第二章:Dockerfile指令与Docker-compose容器编排-搭建docker私有仓库 h1 { color: rgba(0, 60, ...

  4. C#从实习到搬砖

    日常唠唠 没事就聊聊我在c#上踩过的那些坑,和一些笔记 少点比较,多些谦虚 会者不难 原博:轩先生大冒险 2022.4.19 datagridview 修改表头 dataGridView1.Colum ...

  5. Linux 下使用Docker 安装 LNMP环境 超详细

    首先在阿里云购买了一台服务器 选择了华南-深圳地区 操作系统选用了 CentOS8.0 64位 1. 初始化账号密码 登陆xshell,开始装Docker 一.安装docker 1.Docker 要求 ...

  6. 【ASP.NET Core】MVC操作方法如何绑定Stream类型的参数

    咱们都知道,MVC在输入/输出中都需要模型绑定.因为HTTP请求发送的都是文本,为了使其能变成各种.NET 类型,于是在填充参数值之前需 ModelBinder 的参与,以将文本转换为 .NET 类型 ...

  7. MongoDB从入门到实战之MongoDB快速入门

    前言 上一章节主要概述了MongoDB的优劣势.应用场景和发展史.这一章节将快速的概述一下MongoDB的基本概念,带领大家快速入门MongoDB这个文档型的NoSQL数据库. MongoDB从入门到 ...

  8. 彻底弄懂Javascript模块导入导出

    笔者开始学习Javascript的时候,对模块不太懂,不知道怎么导入模块,导出模块,就胡乱一通试 比如 import xx from 'test.js' 不起作用,就加个括号 import {xx} ...

  9. 一、对称加密(DES加密)

    一.DES简介DES是一种对称加密(Data Encryption Standard)算法.于1977年得到美国政府的正式许可,是一种用56位密钥来加密64位数据的方法.一般密码长度为8个字节,其中5 ...

  10. [python] CairoSVG使用教程

    1 CairoSVG介绍 代码下载地址 CairoSVG是一个将SVG1.1转为PNG,PDF, PS格式的转化.SVG算目前火热的图像文件格式了,它的英文全称为Scalable Vector Gra ...