當前位置: 首頁>>代碼示例>>C#>>正文


C# Number.IsZero方法代碼示例

本文整理匯總了C#中System.Number.IsZero方法的典型用法代碼示例。如果您正苦於以下問題:C# Number.IsZero方法的具體用法?C# Number.IsZero怎麽用?C# Number.IsZero使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Number的用法示例。


在下文中一共展示了Number.IsZero方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Pow

		public virtual Number Pow (Number x, Number y)
		{
			if (y.IsZero ())
				return ToElement (Number.One);
			if (y.IsOne ())
				return x;

			Number a = x;
			Number b = ToElement (Number.One);
			if (y.GetBit (0) == 1)
				b = a;
			for (int i = 1; i < y.BitCount (); i ++) {
				a = Multiply (a, a);
				if (y.GetBit (i) == 1)
					b = Multiply (a, b);
			}
			return b;
		}
開發者ID:kazuki,項目名稱:opencrypto.net,代碼行數:18,代碼來源:Classical.cs

示例2: Multiply

		public override unsafe Number Multiply (Number x, Number y)
		{
			if (x.IsZero () || y.IsZero ())
				return Number.Zero;
			if (x.length < y.length) {
				Number swap = x;
				x = y;
				y = swap;
			}
			uint[] z = new uint[mod.length + 1];
			fixed (uint* px = x.data, py = y.data, pz = z, pp = mod.data) {
				uint y0 = py[0];
				int i = 0;
				for (; i < x.length; i++) {
					uint u = (uint)((pz[0] + px[i] * y0) * invMod);
					uint xi = px[i];
					ulong carry1 = ((ulong)xi) * ((ulong)py[0]);
					ulong carry2 = ((ulong)u) * ((ulong)pp[0]);
					ulong carry = (((ulong)(uint)carry1) + ((ulong)(uint)carry2) + ((ulong)pz[0])) >> 32;
					carry1 >>= 32; carry2 >>= 32;
					int k = 1;
					for (; k < y.length; k++) {
						carry1 += ((ulong)xi) * ((ulong)py[k]);
						carry2 += ((ulong)u) * ((ulong)pp[k]);
						carry += ((ulong)(uint)carry1) + ((ulong)(uint)carry2) + ((ulong)pz[k]);
						pz[k - 1] = (uint)carry;
						carry >>= 32; carry1 >>= 32; carry2 >>= 32;
					}
					for (; carry1 != 0 && k < mod.length; k++) {
						carry2 += ((ulong)u) * ((ulong)pp[k]);
						carry += ((ulong)(uint)carry1) + ((ulong)(uint)carry2) + ((ulong)pz[k]);
						pz[k - 1] = (uint)carry;
						carry >>= 32; carry1 >>= 32; carry2 >>= 32;
					}
					for (; k < mod.length; k++) {
						carry2 += ((ulong)u) * ((ulong)pp[k]);
						carry += ((ulong)(uint)carry2) + ((ulong)pz[k]);
						pz[k - 1] = (uint)carry;
						carry >>= 32; carry2 >>= 32;
					}
					carry += carry1 + carry2 + ((ulong)pz[k]);
					pz[k - 1] = (uint)carry;
					pz[k] = (uint)(carry >> 32);
				}
				for (; i < mod.length; i++) {
					uint u = (uint)(pz[0] * invMod);
					ulong carry = (((ulong)u) * ((ulong)pp[0]) + ((ulong)pz[0])) >> 32;
					int k = 1;
					for (; k < mod.length; k++) {
						carry += ((ulong)u) * ((ulong)pp[k]) + ((ulong)pz[k]);
						pz[k - 1] = (uint)carry;
						carry >>= 32;
					}
					carry += ((ulong)pz[k]);
					pz[k - 1] = (uint)carry;
					pz[k] = (uint)(carry >> 32);
				}
				if (pz[mod.length] != 0 || Number.Compare (z, mod.length, mod.data, mod.length) >= 0)
					return new Number (z, Number.Subtract (pz, z.Length, pp, mod.length, pz));
				return new Number (z);
			}
		}
開發者ID:kazuki,項目名稱:opencrypto.net,代碼行數:62,代碼來源:Montgomery.cs


注:本文中的System.Number.IsZero方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。