求助dalao们,51nod1170实在是不会了,有没有大佬讲一下,有兴趣的可以告诉我,我提供AC代码。

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Numerics; namespace Problem51Nod
{
class Program
{
public static void Main(String[] args)
{
//BigInteger m = BigInteger.Pow(5, 143) - 1;
//BigInteger n = BigInteger.Pow(2, 331) + 1;
//int k = 100;
BigInteger m = BigInteger.Parse(Console.ReadLine());
BigInteger n = BigInteger.Parse(Console.ReadLine());
int k = Convert.ToInt32(Console.ReadLine()); //Stopwatch timer = new Stopwatch();
//timer.Start();
Console.WriteLine(Cmn(m, n, k));
//timer.Stop();
//Console.WriteLine(timer.Elapsed);
} static BigInteger[][] PowerTable = new BigInteger[][];
static List<BigInteger[][]>[] PreTable = new List<BigInteger[][]>[];
static BigInteger[,] CMatrix; static void InitCMatrix(int l)
{
CMatrix = new BigInteger[l + , l + ];
for (int i = ; i <= l; i++)
CMatrix[i, ] = CMatrix[i, i] = ; for (int i = ; i <= l; i++)
for (int j = ; j * <= i; j++)
CMatrix[i, j] = CMatrix[i, i - j] = CMatrix[i - , j - ] + CMatrix[i - , j];
} static void InitPowerTab(int l, int p)
{
PowerTable[p] = new BigInteger[l + ];
PowerTable[p][] = ; for (int j = ; j < PowerTable[p].Length; j++)
PowerTable[p][j] = PowerTable[p][j - ] * p;
} static void InitData(int l, BigInteger max, int p)
{
PreTable[p] = new List<BigInteger[][]>();
BigInteger[] pre = MulTo(l, p);
BigInteger[,] cMatrix = new BigInteger[l + , l + ]; for (int i = ; i <= l; i++)
for (int j = ; j <= i; j++)
cMatrix[i, j] = CMatrix[i, j]; int power = ;
for (BigInteger i = p; i <= max; i *= p)
{
BigInteger[][] cTable = new BigInteger[p - ][];
cTable[] = pre;
for (int j = ; j < p; j++)
{
BigInteger[] next = ReplaceWith(cTable[], i * j % PowerTable[p][l], l, p, cMatrix); if (j < p - )
cTable[j] = MulMod(cTable[j - ], next, l, p);
else
pre = MulMod(cTable[j - ], next, l, p);
} PreTable[p].Add(cTable);
power++;
}
} static BigInteger Cmn(BigInteger m, BigInteger n, int l)
{
InitCMatrix(l);
InitPowerTab(l, );
InitPowerTab(l, );
BigInteger up5 = CalP(m, n, , l);
BigInteger up2 = CalP(m, n, , l);
BigInteger mod = ((up5 - up2) + PowerTable[][l]) % PowerTable[][l];
mod = IMod(PowerTable[][l], mod, PowerTable[][l]) * PowerTable[][l] + up2;
return mod;
} static BigInteger CalP(BigInteger m, BigInteger n, int p, int l)
{
BigInteger count = Count(m, p) - Count(n, p) - Count(m - n, p);
if (count > l) return ;
InitData(l, m, p);
BigInteger up = Cal(m, p, l) * PowerTable[p][(int)count];
BigInteger down = Cal(n, p, l);
down *= Cal(m - n, p, l);
down %= PowerTable[p][l];
up = IMod(down, up, PowerTable[p][l]);
return up;
} static BigInteger Count(BigInteger v, BigInteger mod)
{
BigInteger count = ; while (v > )
{
v /= mod;
count += v;
} return count;
} static List<BigInteger> Values = new List<BigInteger>();
static List<int> Mods = new List<int>(); static BigInteger Cal(BigInteger nums, int p, int l)
{
BigInteger numsBak = nums;
Values.Clear();
Mods.Clear(); while (numsBak > )
{
Values.Add(numsBak);
Mods.Add((int)(numsBak % p));
numsBak /= p;
} BigInteger result = ; for (int i = ; i < Values.Count; i++)
{
result *= CalSingle(i, p, l);
result %= PowerTable[p][l];
} return result;
} static BigInteger CalSingle(int cIndex, int p, int l)
{
int len = Mods[cIndex];
BigInteger sum = , last = (Values[cIndex] - len) % PowerTable[p][l];
BigInteger[] pre = new BigInteger[] { };
BigInteger result = ;
cIndex++; for (int i = Mods.Count - ; i >= cIndex; i--)
{
int index = Mods[i]; if (index > )
{
BigInteger modValue = , current = ;
foreach (var item in PreTable[p][i - cIndex][index - ])
{
if (item != )
current = (current + modValue * item) % PowerTable[p][l]; if (sum == || modValue == )
break; modValue = modValue * sum % PowerTable[p][l];
} if (i - cIndex + <= l)
sum = (sum + index * PowerTable[p][i - cIndex + ]) % PowerTable[p][l]; result = (result * current) % PowerTable[p][l];
}
} for (int i = ; i <= len; i++)
{
if (i % p == )
continue; result *= last + i;
result %= PowerTable[p][l];
} return result;
} static BigInteger[] MulTo(int l, int p)
{
BigInteger[] result = new BigInteger[] { }; for (BigInteger i = ; i < p; i++)
{
if (i % p == )
continue; BigInteger[] b = new BigInteger[] { i, };
result = MulMod(result, b, l, p);
} return result;
} static BigInteger[] MulMod(BigInteger[] a, BigInteger[] b, int l, int p)
{
int len = Math.Min(l + , a.Length + b.Length - );
BigInteger[] result = new BigInteger[len]; for (int i = ; i < Math.Min(a.Length, l + ); i++)
{
if (a[i] == )
continue; int upper = Math.Min(b.Length, l - i + );
for (int j = ; j < upper; j++)
result[i + j] += a[i] * b[j];
} int last = ; for (int i = ; i < result.Length; i++)
{
result[i] %= PowerTable[p][l - i];
if (result[i] > )
last = i + ;
} if (last < result.Length)
Array.Resize(ref result, last); return result;
} //2次方算法,考虑大数是3次方 除以大进制的常数
static BigInteger[] ReplaceWith(BigInteger[] source, BigInteger into, int l, int p, BigInteger[,] cMatrix)
{
int len = source.Length;
len = Math.Min(len, l + );
BigInteger[] result = new BigInteger[len];
BigInteger[] power = new BigInteger[len];
power[] = ; for (int i = ; i < len; i++)
power[i] = power[i - ] * into % PowerTable[p][l]; for (int i = ; i < len; i++)
{
if (source[i] == )
continue; for (int j = ; j <= i; j++)
{
if (power[i] == ) continue;
var tmp = power[i - j] * source[i] % PowerTable[p][l - j];
if (tmp == ) continue;
result[j] += tmp * cMatrix[i, j];
}
} for (int i = ; i < result.Length; i++)
result[i] %= PowerTable[p][l - i]; return result;
} public static BigInteger EuclidExtend(BigInteger X, BigInteger Y, out BigInteger A, out BigInteger B)
{
if (Y == ) { A = ; B = ; return X; }
BigInteger quotient = X / Y;
BigInteger gcd = EuclidExtend(Y, X - Y * quotient, out A, out B);
BigInteger Temp = A; A = B; B = Temp - quotient * A;
return gcd;
} public static bool Linear(BigInteger X, BigInteger Y, BigInteger N, out BigInteger xResult, out BigInteger yResult)
{
BigInteger gcd = EuclidExtend(X, Y, out xResult, out yResult);
if (N % gcd != ) { return false; }
xResult = xResult * N / gcd % Y;
xResult = xResult >= ? xResult : xResult + Y;
yResult = yResult * N / gcd % X;
yResult = yResult <= ? yResult : yResult - X;
return true;
} public static BigInteger IMod(BigInteger A, BigInteger B, BigInteger P)
{
BigInteger x, y;
Linear(A, P, B, out x, out y);
return x;
}
}
}

51nod求助的更多相关文章

  1. 51Nod 算法马拉松15 记一次悲壮而又开心的骗分比赛

    OwO 故事的起源大概是zcg前天发现51Nod晚上有场马拉松,然后他就很开心的过去打了 神奇的故事就开始了: 晚上的时候我当时貌似正在写线段树?然后看见zcg一脸激动告诉我第一题有九个点直接输出B就 ...

  2. 【51Nod 1244】莫比乌斯函数之和

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1244 模板题... 杜教筛和基于质因子分解的筛法都写了一下模板. 杜教筛 ...

  3. 51Nod 1268 和为K的组合

    51Nod  1268  和为K的组合 1268 和为K的组合 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 给出N个正整数组成的数组A,求能否从中选出若干个,使 ...

  4. 51Nod 1428 活动安排问题

    51Nod   1428  活动安排问题 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1428 1428 活 ...

  5. 51Nod 1278 相离的圆

    51Nod 1278 相离的圆 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1278 1278 相离的圆 基 ...

  6. 【51Nod 1501】【算法马拉松 19D】石头剪刀布威力加强版

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1501 dp求出环状不连续的前缀和,剩下东西都可以算出来,比较繁琐. 时间 ...

  7. 【51Nod 1622】【算法马拉松 19C】集合对

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1622 简单题..直接暴力快速幂 #include<cstdio&g ...

  8. 【51Nod 1616】【算法马拉松 19B】最小集合

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1616 这道题主要是查询一个数是不是原有集合的一个子集的所有数的gcd. ...

  9. 【51Nod 1674】【算法马拉松 19A】区间的价值 V2

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1674 对区间分治,统计\([l,r]\)中经过mid的区间的答案. 我的 ...

随机推荐

  1. 车牌,车架号,VIN码毫秒识别技术,汽车后市场的春天到来了

    vin码(车架号)识别运用 不仅在制造.销售.保养.保险.车辆评估.交易环节会需要录入汽车的VIN码,在交通事故处理中,作为汽车身份唯一识别码,VIN码是处理事故的执法人员必须要记录的信息之一.随着汽 ...

  2. java计算两个日期之间的天数,排除节假日和周末

    如题所说,计算两个日期之前的天数,排除节假日和周末.这里天数的类型为double,因为该功能实现的是请假天数的计算,有请一上午假的为0.5天. 不够很坑的是每个日期都要查询数据库,感觉很浪费时间. 原 ...

  3. HttpServletResponse 之 sendError( )

    直接返回http 401状态,提示重新登录 response.sendError(401, "当前账户未登录或会话失效,请重新登录!) HTTP状态码列表: 100Continue继续.客户 ...

  4. Struts2(一.基本介绍,环境搭建及需求分析)

    Struts2框架开发 前言 开发工具:eclipse struts1:老项目使用较多,维护时需要用到 struts2:新项目使用较多 一.特点 1. 无侵入式设计 struts2 与 struts ...

  5. 【转】SWFUpload使用指南

    原文出自:http://www.runoob.com/w3cnote/swfupload-guide.html SWFUpload是一个flash和js相结合而成的文件上传插件,其功能非常强大.以前在 ...

  6. 20135313_exp5

    课程:Java程序与设计     班级:1353 姓 名:吴子怡  学号:20135313 小组成员: 20135113肖昱 成绩:             指导教师:娄嘉鹏       实验日期:2 ...

  7. dubbo源码分析1——负载均衡

    dubbo中涉及到的负载均衡算法只要有四种:Random LoadBalance(随机均衡算法).RoundRobin LoadBalance(权重轮循均衡算法).LeastAction LoadBa ...

  8. C++对象模型 多重继承与虚函数表

    一 多重继承 1) 代码: Code#include <iostream>using namespace std; class B1{public:    int x;    virtua ...

  9. EF动态排序

    转载的代码,改天再研究 public PageData<T> FindAll(int PageIndex, int PageSize, Expression<Func<T, b ...

  10. 上传web端——个人项目

    我用visual studio新建了一个web窗口,如图: 然后这里是系统自带的代码: [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile ...