2015NOIP普及组真题 3. 求和

线上OJ:

一本通:http://ybt.ssoier.cn:8088/problem_show.php?pid=1971

核心思想:

本题的约束条件有两个:
条件1、colorx = colorz
条件2、x、y、z的坐标满足 y − x = z − y(即 y 在 x 和 z 的中心位置)
第二个约束条件可以理解为, z 到 x 的距离是 y 到 x 的距离的两倍,所以对z暴力枚举时,步长为2的倍数

在这里插入图片描述

考场上如果暂时没有更好的想法,可以先把 暴力枚举 写出来。本题的暴力法比较简单,只需要枚举x和z,并且在 枚举z的时候考虑步长为2 即可(这样可以保证x和z中间一定有整数y,就不用再考虑y了)。这样可以快速拿到40%的分数。

解法一、暴力枚举(40%)
#include <bits/stdc++.h>
#define MOD 10007
using namespace std;

// 40% 暴力分
int main()
{
    int n, m, ans = 0;
    cin >> n >> m;
	
    int col[n+5], num[n+5];
    for(int i = 1; i <= n; i++) scanf("%d", &num[i]);
    for(int i = 1; i <= n; i++) scanf("%d", &col[i]);	
	
    for(int x = 1; x <= n; x++)
        for(int z = x + 2; z <= n; z += 2)	// 考虑x和z中间夹一个y,所以每次搜寻z时步长为2
        {
            if(col[x] == col[z])
            ans += (((x + z) % MOD) * ((num[x] + num[z]) % MOD)) % MOD;
        }
	
    printf("%d", ans % MOD);  // 最后一次别忘了除模
    return 0;
}
解法二的核心思想:

思考1、对于分颜色的问题如果正向枚举超时,我们可以尝试用 的方式思考。由于满足 c o l o r x = c o l o r z color_x = color_z colorx=colorz 才进行计算,所以在读入数据时 把相同颜色的色块放入同一个桶 中,这样计算时只需要每个桶内进行枚举判断是否满足 z 到 x 的步长为 2 即可。
思考2、对于桶内的编号进一步分析。如下图举例,假设蓝色的色块包含序号为1、3、4、5、6、7、12的色块。我们发现满足 z 到 x 的步长为 2 的色块 要么都是偶数 编号,要么都是奇数 编号。如果我们把奇数和偶数的部分再拆成2个小桶,那么在每个小桶内就不需要枚举判断,而是直接遍历计算每个格子即可。本题的最终结果就是每个小桶的结果之和

在这里插入图片描述

思考3、以上图中蓝色奇数序号的小桶为例,该小桶内的计算公式为,
a n s j = ( x 1 + x 2 ) ∗ ( n u m 1 + n u m 2 ) + ( x 1 + x 3 ) ∗ ( n u m 1 + n u m 3 ) + ( x 1 + x 4 ) ∗ ( n u m 1 + n u m 4 ) ans_j = (x_1+x_2)*(num_1+num_2)+ (x_1+x_3)*(num_1+num_3)+ (x_1+x_4)*(num_1+num_4) ansj=(x1+x2)(num1+num2)+(x1+x3)(num1+num3)+(x1+x4)(num1+num4)
+ ( x 2 + x 3 ) ∗ ( n u m 2 + n u m 3 ) + ( x 2 + x 4 ) ∗ ( n u m 2 + n u m 4 ) \quad \quad \quad + (x_2+x_3)*(num_2+num_3)+ (x_2+x_4)*(num_2+num_4) +(x2+x3)(num2+num3)+(x2+x4)(num2+num4)
+ ( x 3 + x 4 ) ∗ ( n u m 3 + n u m 4 ) \quad \quad \quad + (x_3+x_4)*(num_3+num_4) +(x3+x4)(num3+num4)
= x 1 ∗ ( n u m 1 + n u m 2 ) + x 1 ∗ ( n u m 1 + n u m 3 ) + x 1 ∗ ( n u m 1 + n u m 4 ) \quad \quad = x_1*(num1+num2) + x_1*(num_1+num_3) + x_1*(num_1+num_4) =x1(num1+num2)+x1(num1+num3)+x1(num1+num4)
+ x 2 ∗ ( n u m 1 + n u m 2 ) + x 3 ∗ ( n u m 1 + n u m 3 ) + x 4 ∗ ( n u m 1 + n u m 4 ) \quad \quad \quad + x_2*(num_1+num_2) + x_3*(num_1+num_3) + x_4*(num_1+num_4) +x2(num1+num2)+x3(num1+num3)+x4(num1+num4)
+ x 2 ∗ ( n u m 2 + n u m 3 ) + x 2 ∗ ( n u m 2 + n u m 4 ) \quad \quad \quad + x_2*(num_2+num_3) + x_2*(num_2+num_4) +x2(num2+num3)+x2(num2+num4)
+ x 3 ∗ ( n u m 2 + n u m 3 ) + x 4 ∗ ( n u m 2 + n u m 4 ) \quad \quad \quad + x_3*(num_2+num_3) + x_4*(num_2+num_4) +x3(num2+num3)+x4(num2+num4)
+ x 3 ∗ ( n u m 3 + n u m 4 ) + x 4 ∗ ( n u m 3 + n u m 4 ) \quad \quad \quad + x_3*(num_3+num_4) + x_4*(num_3+num_4) +x3(num3+num4)+x4(num3+num4)
= x 1 ∗ ( n u m 1 + n u m 2 + n u m 1 + n u m 3 + n u m 1 + n u m 4 ) \quad \quad = x_1*(num_1+num_2+num_1+num_3+num_1+num_4) =x1(num1+num2+num1+num3+num1+num4)
+ x 2 ∗ ( n u m 1 + n u m 2 + n u m 2 + n u m 3 + n u m 2 + n u m 4 ) \quad \quad \quad + x_2*(num_1+num_2+num_2+num_3+num_2+num_4) +x2(num1+num2+num2+num3+num2+num4)
+ x 3 ∗ ( n u m 1 + n u m 3 + n u m 2 + n u m 3 + n u m 3 + n u m 4 ) \quad \quad \quad + x_3*(num_1+num_3+num_2+num_3+num_3+num_4) +x3(num1+num3+num2+num3+num3+num4)
+ x 4 ∗ ( n u m 1 + n u m 4 + n u m 2 + n u m 4 + n u m 3 + n u m 4 ) \quad \quad \quad + x_4*(num_1+num_4+num_2+num_4+num_3+num_4) +x4(num1+num4+num2+num4+num3+num4)
= x 1 ∗ ( 2 ∗ n u m 1 + n u m 1 + n u m 2 + n u m 3 + n u m 4 ) \quad \quad = x_1*(2*num_1 + num_1+num_2+num_3+num_4) =x1(2num1+num1+num2+num3+num4)
+ x 2 ∗ ( 2 ∗ n u m 2 + n u m 1 + n u m 2 + n u m 3 + n u m 4 ) \quad \quad \quad + x_2*(2*num_2 + num_1+num_2+num_3+num_4) +x2(2num2+num1+num2+num3+num4)
+ x 3 ∗ ( 2 ∗ n u m 3 + n u m 1 + n u m 2 + n u m 3 + n u m 4 ) \quad \quad \quad + x_3*(2*num_3 + num_1+num_2+num_3+num_4) +x3(2num3+num1+num2+num3+num4)
+ x 4 ∗ ( 2 ∗ n u m 4 + n u m 1 + n u m 2 + n u m 3 + n u m 4 ) \quad \quad \quad + x_4*(2*num_4 + num_1+num_2+num_3+num_4) +x4(2num4+num1+num2+num3+num4)

所以,如果一个小桶内有n个格子,则上述公式可以调整为
a n s j = x 1 ∗ [ ( n − 2 ) ∗ n u m 1 + n u m 1 + n u m 2 + n u m 3 + . . . . . . + n u m n ] ans_j = x_1*[(n-2)*num_1 + num_1+num_2+num_3+......+num_n] ansj=x1[(n2)num1+num1+num2+num3+......+numn]
+ x 2 ∗ [ ( n − 2 ) ∗ n u m 2 + n u m 1 + n u m 2 + n u m 3 + . . . . . . + n u m n ] \quad \quad \quad + x_2*[(n-2)*num_2 + num_1+num_2+num_3+......+num_n] +x2[(n2)num2+num1+num2+num3+......+numn]
+ x 3 ∗ [ ( n − 2 ) ∗ n u m 3 + n u m 1 + n u m 2 + n u m 3 + . . . . . . + n u m n ] \quad \quad \quad + x_3*[(n-2)*num_3 + num_1+num_2+num_3+......+num_n] +x3[(n2)num3+num1+num2+num3+......+numn]
. . . . . . \quad \quad \quad ...... ......
+ x n ∗ [ ( n − 2 ) ∗ n u m 4 + n u m 1 + n u m 2 + n u m 3 + . . . . . . + n u m n ] \quad \quad \quad + x_n*[(n-2)*num_4 + num_1+num_2+num_3+......+num_n] +xn[(n2)num4+num1+num2+num3+......+numn]

我们发现, n u m 1 + n u m 2 + n u m 3 + . . . . . . + n u m n num_1+num_2+num_3+......+num_n num1+num2+num3+......+numn 在初始读入数据时可以顺便计算出来(前缀和),将其表示为 ∑ ( n u m i ) \sum(num_i) (numi),表示该小桶中所有格子的数值之和。
a n s j = x 1 ∗ [ ( n − 2 ) ∗ n u m 1 + ∑ ( n u m i ) ] + x 2 ∗ [ ( n − 2 ) ∗ n u m 2 + ∑ ( n u m i ) ] + . . . . . . ans_j = x_1*[(n-2)*num1 + \sum(num_i)] + x_2*[(n-2)*num2 + \sum(num_i)] + ...... ansj=x1[(n2)num1+(numi)]+x2[(n2)num2+(numi)]+......
+ x n ∗ [ ( n − 2 ) ∗ n u m n + ∑ ( n u m i ) ] \quad \quad \quad + x_n*[(n-2)*num_n + \sum(num_i)] +xn[(n2)numn+(numi)]
= x 1 ∗ ( n − 2 ) ∗ n u m 1 + x 1 ∗ ∑ ( n u m i ) + x 2 ∗ [ ( n − 2 ) ∗ n u m 2 + x 2 ∗ ∑ ( n u m i ) + . . . . . . \quad \quad = x_1*(n-2)*num1 +x_1*\sum(num_i) + x_2*[(n-2)*num2 + x_2* \sum(num_i) +...... =x1(n2)num1+x1(numi)+x2[(n2)num2+x2(numi)+......
+ x n ∗ ( n − 2 ) ∗ n u m n + x n ∗ ∑ ( n u m i \quad \quad \quad + x_n*(n-2)*num_n + x_n*\sum(num_i +xn(n2)numn+xn(numi
= ( n − 2 ) ∗ x 1 ∗ n u m 1 + ( n − 2 ) ∗ x 2 ∗ n u m 2 + . . . . . . + ( n − 2 ) ∗ x n ∗ n u m n \quad \quad = (n-2)*x_1*num1 + (n-2)*x_2*num2 + ...... + (n-2)*x_n*num_n =(n2)x1num1+(n2)x2num2+......+(n2)xnnumn
+ ( x 1 + x 2 + . . . . . . + x n ) ∗ ∑ ( n u m i ) \quad \quad \quad +(x_1+x_2+......+x_n)*\sum(num_i) +(x1+x2+......+xn)(numi)

上式中,(n-2)表示该小桶中格子的数量减2。这个 n 可以在初始 读入数据时先行累加 出来。
因此我们发现,在计算时每一个格子真正参与的部分是:

( n − 2 ) ∗ x i ∗ n u m i + x i ∗ ∑ ( n u m i ) (n-2) * x_i * num_i + x_i * \sum(num_i) (n2)xinumi+xi(numi)

在上式中, x i x_i xi 是格子的编号, n u m i num_i numi 是格子的数值,(n-2)是格子所属小桶中格子的数量-2(可提前计算), ∑ ( n u m i ) \sum(num_i) (numi) 是格子所属小桶中所有格子的数值之和(可提前计算)。至此,已不需要枚举任何数值。
同时, 每个格子不管归属于哪一个小桶,都要参与一次计算,所以把每一个格子都进行一次计算,所得到的总和就是最终的结果

题解代码:
#include <bits/stdc++.h>
#define MOD 10007
#define MAXN 100005
using namespace std;

const int N = 100010, mod = 10007;

int num[MAXN], col[MAXN]; // num[i]表示第i个格子的数字,col[i]表示第i个格子的颜色

//cnt[i][0]表示颜色为i、编号为偶数的格子的个数
int sum[MAXN][2], cnt[MAXN][2]; // sum[i][0]表示颜色为i、编号为偶数的格子上数字的∑wi
                                // sum[i][1]表示颜色为i、编号为奇数的格子上数字的∑wi
                                // cnt[i][0]表示颜色为i、编号为偶数的格子的个数
                                // cnt[i][1]表示颜色为i、编号为奇数的格子的个数

int main()
{
    int n, m, ans = 0;
    cin >> n >> m;

    for(int i = 1; i <= n; i ++) scanf("%d", &num[i]);

    for(int i = 1; i <= n; i ++)
    {
        scanf("%d", &col[i]);   

        // 根据格子的颜色以及奇偶,更新对应桶的∑wi。每个颜色分为奇偶两桶
        sum[col[i]][i % 2] = (sum[col[i]][i % 2] + num[i]) % MOD;
        // 根据格子的颜色以及奇偶,更新对应桶内的格子个数,用于n-2时使用
        cnt[col[i]][i % 2] ++;
    }

    for(int i = 1; i <= n; i ++)
    ans = (ans +  i * ((cnt[col[i]][i % 2] - 2) * num[i] % MOD + sum[col[i]][i % 2])) % MOD;

    printf("%d", ans);
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/567867.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

scipy csr_matrix: understand indptr

See https://stackoverflow.com/questions/52299420/scipy-csr-matrix-understand-indptr

Esp8266 - USB开关分享(开源)

文章目录 简介推广自己gitee项目地址:嘉立创项目地址&#xff1a;联系我们 功能演示视频原理图嘉立创PCB开源地址原理图PCB预览 固件烧录代码编译烧录1. 软件和驱动安装2. 代码编译1. 安装所需要的依赖库文件2. 下载源代码3. 烧录代码 使用说明1. 设备配网2. 打开设备操作页面3…

NAT的知识点和实现

1.NAT的作用&#xff1a; &#xff08;1&#xff09;、把内网私网IP转换公网IP&#xff1b; &#xff08;2&#xff09;、隐藏内网&#xff0c;起到保护内网作用&#xff1b; &#xff08;3&#xff09;、适当的缓解的IPv4地址空间枯竭&#xff1b; &#xff08;4&#xff…

[RTOS 学习记录] 复杂工程项目的管理

[RTOS 学习记录] 复杂工程项目的管理 这篇文章是我阅读《嵌入式实时操作系统μCOS-II原理及应用》后的读书笔记&#xff0c;记录目的是为了个人后续回顾复习使用。 前置内容&#xff1a; 工程管理工具make及makefile 文章目录 1 批处理文件与makefile的综合使用1.1 批处理文件…

Qt实现XYModem协议(五)

1 概述 XMODEM协议是一种使用拨号调制解调器的个人计算机通信中广泛使用的异步文件运输协议。这种协议以128字节块的形式传输数据&#xff0c;并且每个块都使用一个校验和过程来进行错误检测。使用循环冗余校验的与XMODEM相应的一种协议称为XMODEM-CRC。还有一种是XMODEM-1K&am…

4月23号总结

java实现发送邮件 在做聊天室项目的时候&#xff0c;由于需要发送邮箱验证码&#xff0c;所以自己查找了这方面的内容。 首先需要在Maven里面依赖 <dependency><groupId>com.sun.mail</groupId><artifactId>javax.mail</artifactId><versio…

英伟达AI系列免费公开课

英伟达公开课官网地址 Augment your LLM Using Retrieval Augmented Generation Building RAG Agents with LLMs langchain的workflow: ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/c90cb157c9c84bb5b3da380ec56f5c2a.png Generative AI Explained

Linux系统中安装MySQL

1、在电脑中安装虚拟机 2、df -h查看光盘是否挂载&#xff0c;没挂载用mount -o ro /dev/sr0 /media命令挂载 3、进入etc/yum.repos.d目录查看仓是否配置&#xff0c;若配置进行下一一步&#xff0c;未配置则进行配置 配置软件仓库 [rootlocalhost yum.repos.d]# vim rhle.r…

Linux中文件描述符与重定向的深入探索

目录 1. 理解C语言的文件操作函数 2. 操作系统的文件操作接口 3. 文件描述符详解和其内核本质 4. 如何理解Linux下一切皆文件 5. Linux中的重定向 5.1 输出重定向 5.2 追加重定向 5.3 输入重定向 6. 结合文件描述符理解重定向 7.重定向的系统调用 在Linux操作系统中&a…

springboot整合mybatis-plus模版

1.创建springboot项目 Maven类型Lombok依赖Spring Web 依赖MySQL Driver依赖pom.xml&#xff1a;<?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/…

上门废品回收小程序,互联网回收拥有哪些特点?

随着社会的进步&#xff0c;人们的生活水平不断提高&#xff0c;产生的可回收物也在不断上升&#xff0c;每年垃圾站都能产生大量的可回收物&#xff0c;这也造成了资源的浪费。 目前&#xff0c;加快发展回收模式&#xff0c;提高我国回收效率成为了当下回收市场发展的重要方…

[笔试强训day04]

文章目录 WY22 Fibonacci数列NC242 单词搜索BC140 杨辉三角 WY22 Fibonacci数列 WY22 Fibonacci数列 #include<iostream> #include<cmath>using namespace std;int n;int main() {cin>>n;int a0,b1,c1;while(n>c){ab;bc;cab;}int ansmin(n-b,c-n);cout&l…

windows mysql8 安装后 提示密码不对,修改下密码认证方式就可以了

Windows上安装MySQL8后提示密码不对的问题可以通过以下步骤解决&#xff1a; 安装MySQL8 首先&#xff0c;你需要下载并安装MySQL8。你可以从MySQL官方网站下载符合你操作系统版本的安装包。 安装地址是&#xff1a;MySQL :: Download MySQL Installer 安装过程中&#xff…

ACRN Intel推出的虚拟机是啥样的?

前言 ACRN作为Intel为工控领域推出的一个小型化的虚拟机&#xff0c;它的特点主要有这么几个&#xff1a; 1.针对Intel的芯片做了非常强的优化 2.RT-VM实时虚拟机的实时性很好 3.CACHE缓存技术发挥的好 4.TCC技术 / 当然不是所有intel的芯片都支持&#xff0c;&#xff0c…

鸿蒙(HarmonyOS)性能优化实战-多线程共享内存

概述 在应用开发中&#xff0c;为了避免主线程阻塞&#xff0c;提高应用性能&#xff0c;需要将一些耗时操作放在子线程中执行。此时&#xff0c;子线程就需要访问主线程中的数据。ArkTS采用了基于消息通信的Actor并发模型&#xff0c;具有内存隔离的特性&#xff0c;所以跨线…

产品规划|如何从0到1规划设计一款产品?

我们要如何从0到1规划设计一款产品?在前期工作我们需要做什么呢?下面这篇文章就是关于此的相关内容,大家一起往下看多多了解了解吧! 一、什么是产品规划? 产品规划是一种策略,它设定了产品的价值和目标,并确定实施方案以实现这些目标。它考虑了产品的整个生命周期,基于…

[RTOS 学习记录] 工程管理工具make及makefile

[RTOS 学习记录] 工程管理工具make及makefile 这篇文章是我阅读《嵌入式实时操作系统μCOS-II原理及应用》后的读书笔记&#xff0c;记录目的是为了个人后续回顾复习使用。 前置内容&#xff1a; 开发工具 Borland C/C 3.1 精简版 文章目录 1 make 工具2 makefile 的内容结构3…

【学习笔记二十四】EWM补货策略和自动补货配置

一、EWM补货策略概述 1.计划补货 ①以联机或批处理模式启动 ②根据最大和最小数量计算补货 ③仅当库存量低于最低数量时才开始 ④四舍五入至最小补货数量的倍数 2.自动补货 ①在WT确认期间启动 ②根据最大和最小数量计算补货 ③只有当库存量低于最低数量时才开始 ④四舍…

Linux thermal框架介绍

RK3568温控 cat /sys/class/thermal/thermal_zone0/temp cat /sys/class/thermal/thermal_zone1/temp cat /sys/class/thermal/cooling_device0/cur_state cat /sys/class/thermal/cooling_device1/cur_state cat /sys/class/thermal/cooling_device2/cur_state thermal_zone…

翻页电子图书制作小技巧分享给你

当今社会&#xff0c;二维码已经成为了信息传递的重要方式之一&#xff0c;其在电子商务、广告营销、活动推广等领域广泛应用。而如何将二维码巧妙地融入电子画册中&#xff0c;制作出高端、具有吸引力的作品&#xff0c;成为了许多设计师和营销人员关注的焦点 但是很多人却不知…
最新文章