P5691 [NOI2001] 方程的解数(内附封面)

news2024/11/8 19:44:35

[NOI2001] 方程的解数

题目描述

已知一个 n n n 元高次方程:
∑ i = 1 n k i x i p i = 0 \sum\limits_{i=1}^n k_ix_i^{p_i} = 0 i=1nkixipi=0
其中: x 1 , x 2 , … , x n x_1, x_2, \dots ,x_n x1,x2,,xn 是未知数, k 1 , k 2 , … , k n k_1,k_2, \dots ,k_n k1,k2,,kn 是系数, p 1 , p 2 , … p n p_1,p_2,…p_n p1,p2,pn 是指数。且方程中的所有数均为整数。

假设未知数 x i ∈ [ 1 , m ]   ( i ∈ [ 1 , n ] ) x_i \in [1,m] \space ( i \in [1,n]) xi[1,m] (i[1,n]),求这个方程的整数解的个数。

输入格式

第一行一个正整数 n n n,表示未知数个数。
第二行一个正整数 m m m
接下来 n n n 行,每行两个整数 k i , p i k_i,p_i ki,pi

输出格式

输出一行一个整数,表示方程解的个数。

样例 #1

样例输入 #1

3
150
1 2
-1 2
1 2

样例输出 #1

178

提示

【数据范围】

对于 100 % 100\% 100% 的数据, 1 ≤ n ≤ 6 1\le n \le 6 1n6 1 ≤ m ≤ 150 1\le m \le 150 1m150,且
∑ i = 1 n ∣ k i m p i ∣ < 2 31 \sum\limits_{i=1}^n |k_im^{p_i}| < 2^{31} i=1nkimpi<231
答案不超过 2 31 − 1 2^{31}-1 2311 p i ∈ N ∗ p_i \in \mathbb N^* piN

大致思路

首先,把 ∑ i = 1 n k i x i p i = 0 \sum\limits_{i=1}^n k_ix_i^{p_i} = 0 i=1nkixipi=0
拆开得 ∑ i = 1 n / 2 k i x i p i + ∑ i = n / 2 + 1 n k i x i p i = 0 \sum\limits_{i=1}^{n/2} k_ix_i^{p_i} +\sum\limits_{i=n/2+1}^{n} k_ix_i^{p_i} = 0 i=1n/2kixipi+i=n/2+1nkixipi=0
移项得 ∑ i = 1 n / 2 k i x i p i = − ∑ i = n / 2 + 1 n k i x i p i = \sum\limits_{i=1}^{n/2} k_ix_i^{p_i} =-\sum\limits_{i=n/2+1}^{n} k_ix_i^{p_i} = i=1n/2kixipi=i=n/2+1nkixipi=
因此可以考虑折半搜索, meet in the middle
其次,对于幂运算,我们可以使用快速幂求解,效率更令人满意,快速幂代码如下

int quick_poww(int a,int b){
	if(b==1)return a;
	if(b%2==0){
		int tmp=quick_poww(a,b/2);
		return tmp*tmp;
	}
	else {
		int tmp=quick_poww(a,b/2);
		return tmp*tmp*a;
	}
}

若有取模需求,在每次乘法后取模即可。

双dfs部分

对于查找部分,我们可以用基于Hash实现的unordered_map来实现迅速查找的功能,当然也可以手打Hash,set,upper_bound加lower_bound等,个人感觉还是unordered_map好用

以下代码中第一个dfs搜索前半段,后一个dfs搜索后半段,在后一个dfs中进行匹配

#define int long long int
int n,m,p[10],k[10];
int ans1[300],ans2[300],ans=0;
unordered_map<int,int> hass;
void dfs1(int cnt,int sum){
	if(cnt==n/2+1){
		hass[sum]++;
		return;
	}
	for(int i=1;i<=m;i++){
		dfs1(cnt+1,sum+k[cnt]*quick_poww(i,p[cnt]));
	}
	return;
}
void dfs2(int cnt,int sum){
	if(cnt>n){
		ans+=hass[-sum];
		return;
	}
	for(int i=1;i<=m;i++){
		dfs2(cnt+1,sum+k[cnt]*quick_poww(i,p[cnt]));
	}
	return;
}
signed main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		cin>>k[i]>>p[i];
	}
	dfs1(1,0);
	dfs2(n/2+1,0);
	cout<<ans<<endl;
	return 0;
}
}

完整AC CODE

#include<bits/stdc++.h>
using namespace std;
#define int long long int
int n,m,p[10],k[10];
int ans1[300],ans2[300],ans=0;
unordered_map<int,int> hass;
int quick_poww(int a,int b){
	if(b==1)return a;
	if(b%2==0){
		int tmp=quick_poww(a,b/2);
		return tmp*tmp;
	}
	else {
		int tmp=quick_poww(a,b/2);
		return tmp*tmp*a;
	}
}
void dfs1(int cnt,int sum){
	if(cnt==n/2+1){
		hass[sum]++;
		return;
	}
	for(int i=1;i<=m;i++){
		dfs1(cnt+1,sum+k[cnt]*quick_poww(i,p[cnt]));
	}
	return;
}
void dfs2(int cnt,int sum){
	if(cnt>n){
		ans+=hass[-sum];
		return;
	}
	for(int i=1;i<=m;i++){
		dfs2(cnt+1,sum+k[cnt]*quick_poww(i,p[cnt]));
	}
	return;
}
signed main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		cin>>k[i]>>p[i];
	}
	dfs1(1,0);
	dfs2(n/2+1,0);
	cout<<ans<<endl;
	return 0;
}

附封面

请添加图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RabbitMQ 教程 | 第5章 RabbitMQ 管理

&#x1f468;&#x1f3fb;‍&#x1f4bb; 热爱摄影的程序员 &#x1f468;&#x1f3fb;‍&#x1f3a8; 喜欢编码的设计师 &#x1f9d5;&#x1f3fb; 擅长设计的剪辑师 &#x1f9d1;&#x1f3fb;‍&#x1f3eb; 一位高冷无情的编码爱好者 大家好&#xff0c;我是 DevO…

如何理解单例模式? _

例模式(Singleton Pattern)&#xff1a;采取一定的方法保证在整个的软件系统中&#xff0c;对某个类只能存在一个对象实例&#xff0c;并且该类只提供一个取得其对象实例的方法。 通俗点来讲&#xff1a;就是一个男人只能有一个老婆&#xff0c;一个女人只能有一个老公 单例模…

【流量卡奸商自白书】:坑很多,多多少少你得跳一个!

大家好&#xff0c;今天这期短文咱们来讲讲流量卡奸商的自白书&#xff0c;打破你的认知&#xff01;话说虽然没有胆子虚假宣传&#xff0c;没有胆子不给售后&#xff0c;但是呢&#xff0c;整活忽悠消费者来办卡的胆子还是有的&#xff0c;而且还不小。 ​ 作为一个流量卡奸商…

ALLEGRO之Help

本文主要介绍ALLEGRO的Help菜单。 &#xff08;1&#xff09;Documentation&#xff1a;弹出帮助文档&#xff1b; &#xff08;2&#xff09;Whats New&#xff1a;介绍新特性&#xff1b; &#xff08;3&#xff09;Search&#xff1a;暂不清楚&#xff1b; &#xff08;4…

面试之多线程案例(四)

1.单例模式 单例模式是指在内存中只会创建且仅创建一次对象的设计模式。在程序中多次使用同一个对象且作用相同时&#xff0c;为了防止频繁地创建对象使得内存飙升&#xff0c;单例模式可以让程序仅在内存中创建一个对象&#xff0c;让所有需要调用的地方都共享这一单例对象。…

SSL原理详解

SSL协议结构&#xff1a; SSL协议分为两层&#xff0c;下层为SSL记录协议&#xff0c;上层为SSL握手协议、SSL密码变化协议和SSL警告协议。 1.下层为SSL记录协议&#xff0c;主要作用是为高层协议提供基本的安全服务 建立在可靠的传输之上&#xff0c;负责对上层的数据进行分块…

HDFS集群黑白名单机制

HDFS集群黑白名单机制 白名单黑名单 白名单 所谓白名单指的是允许哪些机器加入到当前的HDFS集群中&#xff0c;是一种准入机制白名单由dfs.hosts参数指定&#xff0c;该参数位于hdfs-site.xml.默认值为空dfs.hosts只想文件&#xff0c;该文件包含允许链接到namanode的主机列表…

OpenCVForUnity(九)图片模糊

文章目录 前言一、归一化框滤波器使用blur方法来实现 二、高斯滤波器使用GaussianBlur方法实现 三、中值滤波器使用medianBlur方法实现 四、双边过滤器使用bilateralFilter方法实现 结语 前言 本教程将介绍使用OpenCV中的多种线性滤波器来对图像进行平滑处理&#xff0c;主要包…

程序员面试IT技术岗的三大技巧

文章目录 技巧一&#xff1a;深入研究意向企业技巧二&#xff1a;准备常见的面试问题技巧三&#xff1a;总结经历的面试题 在找工作时&#xff0c;面试是每位程序员必须经历的一关。面对众多求职者竞争激烈的情况&#xff0c;我们需要结合自己的现状&#xff0c;针对意向企业做…

复习第三章反射+IO流

一、反射 JAVA反射机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&#xff1b;对于任意一个对象&#xff0c;都能够调用它的任意一个方法和属性&#xff1b;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机…

在使用Python爬虫时遇到503 Service Unavailable错误解决办法汇总

在进行Python爬虫的过程中&#xff0c;有时会遇到503 Service Unavailable错误&#xff0c;这意味着所请求的服务不可用&#xff0c;无法获取所需的数据。为了解决这个常见的问题&#xff0c;本文将提供一些解决办法&#xff0c;希望能提供实战价值&#xff0c;让爬虫任务顺利完…

机器人科普--AGILOX 叉车

机器人科普--AGILOX 叉车 1 概述2 导航3 驱动轮组4 叉举参考 1 概述 AGILOX 叉车&#xff0c;不需要画地图路径&#xff0c;很厉害。 2 导航 中间路径自由导航&#xff0c;末端规划出轨迹路线&#xff0c;并使用优良的控制器做轨迹追踪。 AGILOX &#xff5c; 10 Min setu…

mysql安装教程保姆级

MySQL免安装本地运行 1.下载MySQL2.创建install.bat3.init.sql 初始创建4.环境变量配置5.运行 install.bat 管理员权限运行6.连接成功遇到的问题 1.下载MySQL ①地址&#xff1a;https://downloads.mysql.com/archives/community/ ②解压 2.创建install.bat 放在mysql>b…

时序预测 | MATLAB实现GRNN广义回归神经网络时间序列预测(多指标,多图)

时序预测 | MATLAB实现GRNN广义回归神经网络时间序列预测(多指标,多图) 目录 时序预测 | MATLAB实现GRNN广义回归神经网络时间序列预测(多指标,多图)效果一览基本介绍程序设计参考资料效果一览 基本介绍 1.MATLAB实现GRNN广义回归神经网络时间序列预测(完整源码和数据) …

hive-date

current_date -- 获取当前系统时间 &#xff0c;获取到的是10 的系统时间 例如 &#xff1a; 2023-07-28 select current_date form edw.test;current_timestamp -- 获取当前的时间戳日期格式&#xff0c;例如 1957-07-27 13:31:21.641 会取到毫秒的一个时间戳格式 select *…

openvino批量推理资料汇总

1、开发者实战 | 基于 C# 和 OpenVINO™ 2023.0部署 YOLOv8 全系列模型_OpenVINO 中文社区的博客-CSDN博客 2、在英特尔 CPU 上加速 Stable Diffusion 推理_OpenVINO 中文社区的博客-CSDN博客 3、 5周年更新 | OpenVINO™ 2023.0&#xff0c;让AI部署和加速更容易_OpenVINO 中…

【C++】—— 多态的基本介绍

前言&#xff1a; 在之前的学习过程中&#xff0c;我们已经对继承进行了详细的学习和了解。今天&#xff0c;我将带领大家学习的是关于 多态 的基本知识。 目录 &#xff08;一&#xff09;多态的概念 1、概念 &#xff08;二&#xff09;多态的定义及实现 1、多态的构成条…

【力扣每日一题】2023.8.1 英雄的力量

目录 题目&#xff1a; 示例&#xff1a; 分析&#xff1a; 代码&#xff1a; 题目&#xff1a; 示例&#xff1a; 分析&#xff1a; 题目给我们一个数组&#xff0c;让我们找出数组的每个非空子数组&#xff08;不用连续&#xff09;&#xff0c;然后按照公式算出子数组的…

CNN、数据预处理、模型保存

目录 CNN代码读取数据搭建CNN训练网络模型 数据增强迁移学习图像识别策略数据读取定义数据预处理操作冻结resnet18的函数把模型输出层改成自己的设置哪些层需要训练设置优化器和损失函数训练开始训练再训练所有层关机了&#xff0c;再开机&#xff0c;加载训练好的模型 CNN 代码…

计算机网络(2) --- 网络套接字UDP

计算机网络&#xff08;1&#xff09; --- 网络介绍_哈里沃克的博客-CSDN博客https://blog.csdn.net/m0_63488627/article/details/131967378?spm1001.2014.3001.5501 目录 1.端口号 2.TCP与UDP协议 1.TCP协议介绍 1.TCP协议 2.UDP协议 3.理解 2.网络字节序 发送逻辑…