求解ax + by = c 这类方程

  基础知识:

  1.对于任意的ax+by=c, 如果我们知道有一组解x0, y0; 那么 x1 = x0+kb'(b'=b/gcd(a,b)), y1 = y0-ka'(a'=a/gcd(a,b));

  求解ax + by = c 的过程如下:

  1.首先我们利用Egcd求出ax+by=g(g = gcd(a,b))的解。 利用此算法我们可以求出三个数g, x, y

  2.然后我们判断c%g==0? 如果不等于0, 那么此方程无整数解。如果等于0的时候那么执行第三步

  3.利用g, x, y, c我们求出ax+by=c的一组解x0 = x*c/g, y0 = y*c/g;

  4.现在我们利用基础知识1可以求解出ax+by=c的任意一组解。当求最小的满足条件的x的时候我们可以利用模运算:

  实例: POJ1061

  题意是有两只青蛙在赤道上跳, 第一只青蛙的起点是x, 每次跳m米, 第二只从y开始每次跳n米, 赤道长度为l, 问两只青蛙最少几步相遇?

  我们可以列出如下方程x+km = y+kn mod(l) => k(m-n) + k1*l = y-x, 代码如下:

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>using namespace std;
typedef long long LL;void gcd(LL a, LL b, LL &d, LL &x, LL &y)
{if(!b) { d=a; x=1; y=0;}else { gcd(b, a%b, d, y, x); y -= x*(a/b); }
}int main()
{LL x, y, m, n, l;cin>>x>>y>>m>>n>>l;LL a=m-n, b=l, c=y-x;LL g;gcd(a, b, g, x, y);if(c%g != 0){cout<<"Impossible"<<endl;return 0;}LL x0 = c/g*x;//x1 = x0+k*b/gLL bg = b/g>0?b/g:-b/g;x0 = (x0%bg+bg)%bg;           //这里使用模运算求解最小值cout<<x0<<endl;return 0;
}

 

    

转载于:https://www.cnblogs.com/xingxing1024/p/5189714.html

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

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

相关文章

ubuntu server修改系统时区和系统时间

From: http://gaoke0820.blog.163.com/blog/static/2166496520121118113743252/ 修改系统时区&#xff1a; sudo nano /etc/timezone 输入&#xff1a;Asia/Shanghai 也可以使用以下命令打开交互式界面来更改系统时区&#xff1a; sudo dpkg-reconfigure tzdata 修改系统时间&…

Vue3中的混入(mixins)

本文主要介绍Vue3中的混入&#xff08;mixins&#xff09;。 目录 一、在普通写法中使用混入&#xff1a;二、在setup写法中使用混入&#xff1a; 混入是Vue中一种用于在组件中共享可复用功能的特性。在Vue 3中&#xff0c;混入的使用方式有所改变。 一、在普通写法中使用混入…

[Redux/Mobx] redux它的三个原则是什么?

[Redux/Mobx] redux它的三个原则是什么&#xff1f; 单一数据源: 整个应用的只有一个store&#xff0c;store的state存在于唯一的object tree上state只读&#xff1a;state不可操作&#xff0c;要修改state&#xff0c;需要触发action&#xff0c;让reducer函数中返回一个全新…

android 打电话

startActivity(new Intent(Intent.ACTION_CALL, Uri.parse("tel:xxxxxxxxxxx")));转载于:https://www.cnblogs.com/hsji/p/5192191.html

[Redux/Mobx] redux-saga和redux-thunk有什么本质的区别?

[Redux/Mobx] redux-saga和redux-thunk有什么本质的区别&#xff1f; saga 自己基本上完全弄了一套 asyc 的事件监听机制。虽然好的一方面是将来可以扩展成 worker 相关的模块&#xff0c;甚至可以做到 multiple threads 同时执行&#xff0c;但代码量大大增加。如果只是普通的…

RTSP协议

From: http://www.cnblogs.com/Jimmly/archive/2009/07/27/1531999.html RTSP是由Real network 和Netscape共同提出的如何有效地在IP网络上传输流媒体数据的应用层协议。 实时流协议&#xff08;RTSP&#xff09;建立并控制一个或几个时间同步的连续流媒体&#xff0c;如音频和…

[Redux/Mobx] 在redux中,什么是reducer?它有什么作用?

[Redux/Mobx] 在redux中&#xff0c;什么是reducer&#xff1f;它有什么作用&#xff1f; reducer的作用 : 根据 action 对象的type 来更新状态. reducer的工作方式 : 接收一个 state 参数, 作为初始的 state 接收一个action对象, 在函数体中用 switch 语句 判断 action 的ty…

win7 下的 cmdhere 及其他

From: http://hi.baidu.com/su_xue_2008/item/80aa62d01455b9bf33db9099 对xp命令行熟悉的朋友都知道xp下有个小工具叫cmdhere. 它给文件夹右键菜单加上了一个"cmdhere" 选项, 点击即可打开控制台, 并且控制台的当前位置, 已经是右键点击的文件夹位置. 它只是一个很小…

CSS3 动画 思维导图

思维导图在新窗口打开浏览 转载于:https://www.cnblogs.com/weaming/p/5193044.html

[Redux/Mobx] 什么是redux?说说你对redux的理解?有哪些运用场景?

[Redux/Mobx] 什么是redux&#xff1f;说说你对redux的理解&#xff1f;有哪些运用场景&#xff1f; Redux是一个数据管理的库&#xff0c;它除了将数据存储在单一数据源中之外&#xff0c;还确定了变更数据、读取数据的方式&#xff0c;以此来明确了数据的来源&#xff0c;方…

做论坛签名外链 我们需要注意什么?

相信每位站长除了日常的网站维护工作之外&#xff0c;外链工作也是每日必不可少的&#xff0c;然而在这个外链路径越来越窄的互联网&#xff0c;论坛签名外链无疑是我们站长首选之一&#xff0c;毕竟这样的链接收录强大&#xff0c;质量较好&#xff0c;并且我们在做这些外链的…

python+PyQT+Eric安装配置

From: http://www.cnblogs.com/lhj588/archive/2011/10/03/2198472.html 一、大纲内容&#xff1a; 1、预备PC环境&#xff1a; 2、预备安装程序: 2、1、下载Python3.2 2、2、下载PyQt4 2、3、下载Eric5 3、安装配置步骤&#xff1a; 3、1、安装Pyhon3.2 3、2、安装PyQt4 3、3、…

奖学金

【问题描述】某小学最近得到了一笔赞助&#xff0c;打算拿出其中一部分为学习成绩优秀的前5名学生发奖学金。期末&#xff0c;每个学生都有3门课的成绩&#xff1a;语文、数学、英语。先按总分从高到低排序&#xff0c;如果两个同学总分相同&#xff0c;再按语文成绩从高到低排…

[Redux/Mobx] redux的thunk作用是什么?

[Redux/Mobx] redux的thunk作用是什么&#xff1f; 作用&#xff1a;通过redux-thunk这个中间件&#xff0c;改变了redux中原本dispatch函数的作用&#xff0c;使它可以接受一个function作为dispatch的对象&#xff1b;在使用上&#xff0c;可以在这个function上进行异步操作&…

Python3.2官方文档翻译--作用域和命名空间

6.2 Python作用域和命名空间 在介绍类之前。首先我想告诉你一些关于python作用域的规则。类的定义很巧妙地运用了命名空间&#xff0c;你须要知道范围和命名空间的工作原理以能全面了解接下来发生的。 顺便说一下&#xff0c;关于这节讲到的知识对于不论什么优秀的python程序猿…

[react] 你觉得react上手快不快?它有哪些限制?

[react] 你觉得react上手快不快&#xff1f;它有哪些限制&#xff1f; 相对vue来说不快。 限制 需要学习JSX需要工程化的配置需要对原生JavaScript有相当的掌握react只是一个UI层面的库&#xff0c;像vue内置了动画处理、keep-alive等功能&#xff0c;react则需要去找第三方库…

ffmpeg解码流程 turorial5详解

From: http://www.360doc.com/content/11/1117/09/8050095_165108638.shtml FFMPEG解码流程 1. 注册所有容器格式和CODEC:av_register_all() 2. 打开文件:av_open_input_file() 3. 从文件中提取流信息:av_find_stream_info() 4. 穷举所有的流&#xff0c;查找其中种类为CODE…

Windows phone7 开发-Zune software is not launched 【转】

刚学习Windows Phone7开发&#xff0c;遇到这个配置错误&#xff0c;在此记录一下。 错误提示&#xff1a;Zune软件未安装 Zune software is not installed. Install the latest version of Zune software. 遇到这个问题&#xff0c;尝试根据提示&#xff0c;按图索骥&#xf…

[react] 说说你喜欢react的原因是什么?它有什么优缺点?

[react] 说说你喜欢react的原因是什么&#xff1f;它有什么优缺点&#xff1f; 原因&#xff1a; All in JS&#xff0c;没有过多的语法糖、API等&#xff0c;核心思想就是props、state、生命周期、hooks&#xff0c;使用JS的技能就能解决和解释一切现象优点&#xff1a; 使用…

淘宝(taobao)HSF框架

一、背景 随着网站访问量增加&#xff0c;仅仅靠增加机器已不能满足系统的要求&#xff0c;于是需要对应用系统进行垂直拆分和水平拆分。在拆分之后&#xff0c;各个被拆分的模块如何通信&#xff1f;如何保证 性能&#xff1f;如何保证各个应用都以同样的方式交互&#xff1f;…