洛谷 题解 P2312 【解方程】

Problem

P2312 【解方程】 >>>

record

  • 用时: 1166ms
  • 空间: 780KB(0.76MB)
  • 代码长度: 2.95KB
  • 提交记录: R9909587 >>>
  • 注: 使用了
    1. o1 优化
    2. o2 优化
    3. o3 优化
    4. 快读快输 >>>

Solution

30 pts

枚举,使用 int,直接按题目所说暴力乱搞一通

Unaccepted 30
Ac:3
Wa:7

50 pts

∣a_i∣≤10^10000

所以高精度。

然而慢的一皮:

Unaccepted 50
Ac:5
Tle:5

评测记录 >>>

30 pts

考虑暴力优化。

考虑在模意义下进行暴力,可以减小误差。

注意:模的应该是质数,且应该多模数,防止误差。

质数应该多记住几个,考场上的时候很有用(如:哈希)

然后。。。就出锅了。

评测记录 >>>

Unaccepted 30
Ac:3
Wa:7

100 pts

请大家在NOIp上一定要:开 long long!

评测记录 >>>

Accepted 100
Ac:10

Code

// luogu-judger-enable-o2
/*** Problem: P2312 解方程. * Author:  航空信奥. * Date:    2018/08/19. * Upload:  Luogu. */
#pragma GCC optimize("O1")
#pragma GCC optimize("O2")
#pragma GCC optimize("O3")
#include <stdio.h>
#include <vector>
using namespace std;namespace hkxadpall {char BufferRead[1 << 15];int rLen = 0, rPos = 0;inline char Getchar(){if (rPos == rLen) rPos = 0, rLen = fread(BufferRead, 1, 1 << 15, stdin);if (rPos == rLen) return EOF;return BufferRead[rPos++];} template <typename _TpInt> inline _TpInt read();template <typename _TpInt> inline void write(_TpInt x);#   define Max_N 103
#   define Mod1  10007LL
#   define Mod2  19260817LL
#   define Mod3  100000007LLint n, m;long long a1[Max_N];long long a2[Max_N];long long a3[Max_N];bool isRight(long long *a, int x, long long mod){long long ans = a[n];for (int i = n - 1; i >= 0; i--) {ans = (ans * x + a[i]) % mod;}return (ans == 0);}int main() {   n = read<int>();m = read<int>();for (int i = 0; i <= n; i++) {bool flag = 0;char c = Getchar();while ((c > '9' || c < '0') && c != '-') c = Getchar();if (c == '-') flag = 1, c = Getchar();a1[i] = (c & 15);a2[i] = (c & 15);a3[i] = (c & 15);while ((c = Getchar()) <= '9' && c >= '0') {a1[i] = ((a1[i] * 10) + (c & 15)) % Mod1;a2[i] = ((a2[i] * 10) + (c & 15)) % Mod2;a3[i] = ((a3[i] * 10) + (c & 15)) % Mod3;}if (flag) {a1[i] = Mod1 - a1[i]; a2[i] = Mod2 - a2[i]; a3[i] = Mod3 - a3[i]; }}vector <int> answer;for (int i = 1; i <= m; i++) {if (isRight(a1, i, Mod1)&& isRight(a2, i, Mod2)&& isRight(a3, i, Mod3)) answer.push_back(i);}printf("%d\n", answer.size());for (int i = 0; i < answer.size(); i++)write(answer[i]), putchar(10);return 0;}template <typename _TpInt>inline _TpInt read()       {register int flag = 1;register char c = Getchar();while ((c > '9' || c < '0') && c != '-') c = Getchar();if (c == '-') flag = -1, c = Getchar();register _TpInt init = (c & 15);while ((c = Getchar()) <= '9' && c >= '0') init = (init << 3) + (init << 1) + (c & 15);return init * flag;}template <typename _TpInt>inline void write(_TpInt x){if (x < 0) {putchar('-');write<_TpInt>(~x + 1);}else {if (x > 9) write<_TpInt>(x / 10);   putchar(x % 10 + '0');}}
}int main()
{hkxadpall::main();return 0;
}

转载于:https://www.cnblogs.com/hkxadpall/p/9895943.html

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

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

相关文章

python列表遍历 空列表_Python list列表执行reversed()后执行pop()返回迭代对象遍历为空问题...

1、示例代码1)一般情况s [1,2,3]t reversed(s)for i in t:print(i)# 输出: 3,2,12) 执行pop()s [1,2,3]t reversed(s)s.pop()for i in t:print(i)# 期望输出 : 2, 1# 实际什么都没输出:2、问题原因及示例代码返回的迭代器本质上需要知道最后一个索引的位置和列表的长度。如…

cant find module express

安装express成功&#xff0c;测试一个应用如下&#xff1a;但是&#xff0c;运行却报错&#xff0c;如下图&#xff1a;说是express找不到&#xff0c;不应该啊&#xff01;命令都能用啊&#xff01;表面的原因是因为我install express用的是-g。参考链接如下&#xff1a;http:…

Linux虚拟机sqlite数据库安装教程、命令实现sqlite

参考&#xff1a;Linux虚拟机sqlite数据库安装教程 作者&#xff1a;图触靓 发布时间&#xff1a; 2021-04-08 19:07:56 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/115528254 一、在官网下载压缩包到window里面 SQLite官网下载地址 如图我们下载sqlite-a…

SecureCRT 使用 rz命令提示waiting to receive.**B0100000023be50

SecureCRT 远程连接Linux服务器&#xff0c;使用 rz命令提示waiting to receive.**B0100000023be50&#xff0c;或者使用sz命令提示&#xff1a; **B0100000023be50 解决方法设置如下&#xff1a; 转载于:https://www.cnblogs.com/pandaly/p/9898173.html

C语言面试高频问题:自己代码实现字符串相关的常用API

参考&#xff1a;C语言面试高频问题&#xff1a;自己代码实现字符串相关的常用API 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-08-08 13:31:33 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107878102 目录1、实现get(char *)&#xff1b;从键盘获取…

Python时间复杂度计算题答案

评论 题目链接 https://blog.csdn.net/qq_33254766/article/details/132255078 答案 时间复杂度&#xff1a;O(n)。 分析&#xff1a;这段代码遍历了n次&#xff0c;所以时间复杂度是线性的&#xff0c;即O(n)。 时间复杂度&#xff1a;O(n^2)。 分析&#xff1a;两个嵌套的…

【性能优化】优化笔记之一:图像RGB与YUV转换优化

本文主要介绍如何优化您自己的CODE&#xff0c;实现软件的加速。我们一个图象模式识别的项目&#xff0c;需要将RGB格式的彩色图像先转换成黑白图像。图像转换的公式如下&#xff1a; Y 0.299 * R 0.587 * G 0.114 * B 图像尺寸640*480*24bit&#xff0c;RGB图像已经按照RGB…

wxpython使用方法_python图形界面开发之wxPython树控件使用方法详解

wxPython树控件介绍树(tree)是一种通过层次结构展示信息的控件&#xff0c;如下图所示是树控件示例&#xff0c;左窗口中是树控件&#xff0c;在wxPython中树控件类是wx.TreeCtrl。wx.TreeCtrl常用的方法有AddRoot(text, image-1, selImage-1, dataNone)。添加根节点&#xff0…

DSP_SCI

F2833x Serial Communication Interface 簡介 串行通信接口&#xff08;SCI&#xff09;模塊是一個串行I / O端口&#xff0c;允許F2833x與其他外圍設備之間的異步通信。 它通常被稱為UART&#xff08;通用異步接收器發送器&#xff09;&#xff0c;通常根據RS232標準使用。 SC…

如何让自己的写的程序在阿里云一直运行

参考&#xff1a;如何让自己的写的程序在阿里云一直运行 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-08-02 11:53:28 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107742311 目录1、下载screen&#xff1a;2、运行screen&#xff0c;创建一个scree…

C程序设计语言--第五章:指针与数组

为什么80%的码农都做不了架构师&#xff1f;>>> 指针是一种保存变量地址的变量. 5.1 指针与地址 通常的机器都有一系列连续编号或编址的存储单元,这些存储单元可以单个进行操纵,也可以连续成组的方式操纵.指针是能够存放一个地址的一组存储单元(通常是两个或四个…

java list 自定义类型转换_使用Java Stream API将List按自定义分组规则转换成Map的一个例子...

本文完整测试代码见文末。测试数据是List里的4个员工对象实例&#xff1a;根据员工所在的城市进行分组&#xff1a;结果分成了三组&#xff1a;第一组的员工在上海&#xff1a;第二组的员工在成都&#xff1a;统计每组员工个数&#xff1a;把员工进行分组&#xff0c;得分大于1…

安卓app与阿里云服务器的无线通信(非局域网)

参考&#xff1a;安卓app与阿里云服务器的无线通信&#xff08;非局域网&#xff09; 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-08-01 16:13:14 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107732156 目录写在阿里云里面的服务器代码&#xff1…

10.继承和派生

2019独角兽企业重金招聘Python工程师标准>>> 类成员访问权限&#xff1a; 成员访问权限&#xff1a;私有成员&#xff1a;只能被类自身的成员和友元访问&#xff1b; 公有成员&#xff1a;可以被任何普通函数和任何类的成员函数或子类访问&#xff1b; 保护成员&a…

1185 威佐夫游戏 V2

1185 威佐夫游戏 V2 有2堆石子。A B两个人轮流拿&#xff0c;A先拿。每次可以从一堆中取任意个或从2堆中取相同数量的石子&#xff0c;但不可不取。拿到最后1颗石子的人获胜。假设A B都非常聪明&#xff0c;拿石子的过程中不会出现失误。给出2堆石子的数量&#xff0c;问最后谁…

java date 判断是否是今天_java——推断日期是否在今天之前

这里说的日期是指字符串的日期格式&#xff0c;如“2014-10-15”&#xff0c;我们要推断这个日期是否在今天之前&#xff0c;网上看到好多推断的方法&#xff0c;都是拿这个日期转换成Date对象 然后与new Date()比較&#xff0c;使用comparetTo() 或者before()方法&#xff0c…

树莓派与阿里云服务器之间的无线通信(非局域网)

参考&#xff1a;Linux虚拟机sqlite数据库安装教程 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-08-01 15:45:026 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107731166 购买服务器后。我们可以点击控制台&#xff0c;找到实例列表&#xff0c;点击…

IOS开发博客学习

M了个J :http://www.cnblogs.com/mjios/tag/objective-c/ http://www.cnblogs.com/tianjian/p/3358602.html Cocos2d-x VS环境配置 泰然论坛&#xff1a;http://www.ityran.com/archives/category/cocos2d-iphone 1.http://www.cnblogs.com/zilongshanren/archive/2011/09/19…

CLR via C#学习笔记-第十三章-定义接口、继承接口

13.1 类和接口继承 接口是为了实现多继承 所有的类都继承了System.Object&#xff0c;及其四个公共实例方法&#xff1a;ToString、Equals、GetHashCode、GetType。 CLR允许定义接口&#xff0c;它实际只是对一组方法签名进行了统一命名。这些方法不提供任何实现。 类通过指定接…