热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

hdu1573非互素的中国剩余定理(疑似有错)

*大牛的思路:典型的中国剩余定理,但是这里是非互质情况下的中国剩余定理。解题思路:1.因为(a1,a2,a3,a4,….,ak)不一定互质,所以不能够直接用中国剩余定理。2

/*大牛的思路:
典型的中国剩余定理,但是这里是非互质情况下的中国剩余定理。
解题思路:
1.因为(a1,a2,a3,a4,….,ak)不一定互质,所以不能够直接用中国剩余定理。
2.x=r1+a1*k1,x=r2+a2*k2,所以有r1+a1*k1=r2+a2*k2,化简后得到 a1*k1=(r2-r1) mod(a2);
用扩展欧几里得可以得到最小的k1,所以x=r1+a1*k1+a1*a2/gcd(a1,a2),
就这样一直替换最后剩余一个同余方程。r1就是最后的解。
对于x=a1 mod b1,x= a2 mod b2,设x=a1+m*b1
所以b1*m=a2-a1 mod b2,利用欧几里德扩展定理求出最小的非负m,
那么x=a1+m*b1就已知,且x最小,如果无解,整个同余式组无解
同时,x+k*b1是所有满足x=a1 mod b1的解,而x+k‘*b2又是所有满足x=a2 mod b2的解
那么,将x+k*b1与x+k‘*b2合并,得到的式子就是x+k*lcm(b1,b2)
于是,上面两个式子可以用x‘=x mod lcm(b1,b2)来替代
最后,就只剩下一个式子了,求得的最小的x就是答案
对于一次同余式ax=b mod n,设d=gcd(a,n),则同余式有解的充要条件为d|b
假设d=a*x‘+n*y‘,则x0=b/d*x‘一定为方程组的一个解,且共有d个解,
(证明可以参考算法导论)最小正整数解为(x0%n/d+n/d)%(n/d)
*/
#include
#include
#include
#include
using namespace std;
typedef __int64 IntType;
IntType mod(IntType value,IntType modeNum)//求模运算,考虑负数
{
if(value <0)
value = value+((-value)/modeNum+1)*modeNum;
return value%modeNum;
}
IntType exgcd(IntType a,IntType b,IntType &x,IntType &y){//ax+by = 1
if( b == 0 ) {
x = 1;
y = 0;
return a;
}
else{
IntType x1,y1;
IntType d = exgcd ( b , mod(a,b) , x1 , y1 );
x = y1;
y= x1 - a / b * y1;
return d;
}
}
int main()
{
IntType n,m,temp;
IntType num[11],k;
IntType a[11],b[11];
IntType t;
scanf("%I64d",&t);
while(t--)
{
scanf("%I64d %I64d",&n,&m);
for(IntType i = 0; i {
scanf("%I64d",&a[i]);
}
for(IntType i = 0; i {
scanf("%I64d",&b[i]);
}
bool flag = true;
for(IntType i = 1; i {
IntType r = b[0] - b[i];
IntType k2,k1,c;
c = exgcd(a[i],a[0],k2,k1);
/*printf("gcd(%ld,%ld) = %ld\n",a[i],a[0],c);
printf("%ld * %ld = %ld (mod %d)\n",a[i],k2,c,a[0]);*/
if(mod(r,c) != 0)
{
flag = false;
break;
}
a[0] = a[0]/c*a[i];//a[0]变为lcm(a[0],a[i])
b[0] = mod((a[i]*k2*r/c)+b[i],a[0]);
/*printf("b[0] = %ld\n",b[0]);*/
}
if(flag == false||b[0] > n)
printf("0\n");
else
{
if(b[0] == 0)
printf("%I64d\n",(n-b[0])/a[0]);
else
printf("%I64d\n",(n-b[0])/a[0]+1);
}
}
return 0;
}

 

本文出自 “Qero” 博客,请务必保留此出处http://8590696.blog.51cto.com/8580696/1358917


推荐阅读
  • andr ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • VPX611是北京青翼科技推出的一款采用6U VPX架构的高性能数据存储板。该板卡搭载两片Xilinx Kintex-7系列FPGA作为主控单元,内置RAID控制器,支持多达8个mSATA盘,最大存储容量可达8TB,持续写入带宽高达3.2GB/s。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 图数据库中的知识表示与推理机制
    本文探讨了图数据库及其技术生态系统在知识表示和推理问题上的应用。通过理解图数据结构,尤其是属性图的特性,可以为复杂的数据关系提供高效且优雅的解决方案。我们将详细介绍属性图的基本概念、对象建模、概念建模以及自动推理的过程,并结合实际代码示例进行说明。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 本文介绍了如何通过扩展 UnityGUI 创建自定义和复合控件,以满足特定的用户界面需求。内容涵盖简单和静态复合控件的实现,并展示了如何创建复杂的 RGB 滑块。 ... [详细]
author-avatar
奶油晓生2502876643
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有