亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? t_mptest.c

?? 大數(shù)的計算包括加減乘除
?? C
字號:
/* t_mpTest.c */

/******************* SHORT COPYRIGHT NOTICE*************************
This source code is part of the BigDigits multiple-precision
arithmetic library Version 1.0 originally written by David Ireland,
copyright (c) 2001 D.I. Management Services Pty Limited, all rights
reserved. It is provided "as is" with no warranties. You may use
this software under the terms of the full copyright notice
"bigdigitsCopyright.txt" that should have been included with
this library. To obtain a copy send an email to
<code@di-mgt.com.au> or visit <www.di-mgt.com.au/crypto.html>.
This notice must be retained in any copy.
****************** END OF COPYRIGHT NOTICE*************************/

#include <stdio.h>
#include <assert.h>
#include "bigdigits.h"

#define TEST_LEN MAX_DIG_LEN	

DIGIT_T w[TEST_LEN]; 
DIGIT_T u[TEST_LEN];
DIGIT_T v[TEST_LEN];
DIGIT_T q[TEST_LEN];
DIGIT_T r[TEST_LEN];
DIGIT_T p1[TEST_LEN];
DIGIT_T p2[TEST_LEN];
DIGIT_T p3[TEST_LEN];
DIGIT_T g[TEST_LEN];

void ClearAll(void)
{
	mpSetZero(u, TEST_LEN);
	mpSetZero(v, TEST_LEN);
	mpSetZero(w, TEST_LEN);
	mpSetZero(q, TEST_LEN);
	mpSetZero(r, TEST_LEN);
	mpSetZero(g, TEST_LEN);
	mpSetZero(p1, TEST_LEN);
	mpSetZero(p2, TEST_LEN);
	mpSetZero(p3, TEST_LEN);
}

static int MakeMultiplePrime(DIGIT_T p[], unsigned int ndigits)
{	/* Returns a random prime number of ndigits */
	/*	WARNING: This is not cryptographically secure 
		because the random number generator isn't */
	unsigned int i;

	for (i = 0; i < ndigits; i++)
		p[i] = spPseudoRand(0, MAX_DIGIT);

	/* Make sure the highest and low bits are set */
	p[ndigits - 1] |= HIBITMASK;
	p[0] |= 0x1;

	/*printf("p="); mpPrintNL(p, ndigits);*/

	/* Check if prime */
	while (!mpIsPrime(p, ndigits, 10))
	{
		/* Keep adding 2 until find a prime */
		mpShortAdd(p, p, 2, ndigits);

		/*printf("p="); mpPrintNL(p, ndigits);*/
		printf(".");

		/* Check for overflow */
		if (!(p[ndigits - 1] & HIBITMASK))
			return -1;	/* Failed to find a prime */
	}

	return 0;
}

unsigned int MakeMultipleRandom(DIGIT_T a[], unsigned int ndigits)
{
	/* Make a random number of up to ndigits digits */ 
	unsigned int i, n, bits;
	DIGIT_T mask;

	n = (unsigned int)spPseudoRand(1, ndigits);
	for (i = 0; i < n; i++)
		a[i] = spPseudoRand(0, MAX_DIGIT);
	for (i = n; i < ndigits; i++)
		a[i] = 0;

	/*	Zero out a random number of bits in leading digit 
		about half the time */
	bits = (unsigned int)spPseudoRand(0, 2*BITS_PER_DIGIT);
	if (bits != 0 && bits < BITS_PER_DIGIT)
	{
		mask = HIBITMASK;
		for (i = 1; i < bits; i++)
		{
			mask |= (mask >> 1);
		}
		mask = ~mask;
		a[n-1] &= mask;
	}
	return n;
}

void ShowAdd(DIGIT_T w[], DIGIT_T u[], DIGIT_T v[], 
			 DIGIT_T carry, unsigned int ndigits)
{
	printf("mpAdd: ");
	mpPrintTrim(u, ndigits);
	printf("+ ");
	mpPrintTrim(v, ndigits);
	printf("= ");
	mpPrintTrim(w, ndigits);
	printf(", Carry = %lx\n", carry);
}

main()
{
	DIGIT_T carry, m;

	/*	Force linker to include copyright notice in 
		executable object image
	*/
	copyright_notice();
		
	ClearAll();

	/* Start easy: 1 + 1 = 2 */
	mpSetDigit(u, 1, TEST_LEN);	/* u = 1 */
	carry = mpAdd(w, u, u, TEST_LEN);	/* w = u + u */
	ShowAdd(w, u, u, carry, TEST_LEN);
	/* Check that w == 2 */
	assert(mpShortCmp(w, 2, TEST_LEN) == 0);

	/* ---- Add and subtract ---- */
	/* Add two random numbers w = u + v */
	MakeMultipleRandom(u, TEST_LEN-1);
	MakeMultipleRandom(v, TEST_LEN-1);
	carry = mpAdd(w, u, v, TEST_LEN);

	/* r = w - v */
	carry = mpSubtract(r, w, v, TEST_LEN);

	/* Check r == u */
	assert(mpEqual(r, u, TEST_LEN));
	printf("Add and subtract worked OK\n");
	ClearAll();

	/* ---- Multiply and divide ---- */
	/* Multiply two random numbers w = u * v */
	MakeMultipleRandom(u, TEST_LEN / 2);
	MakeMultipleRandom(v, TEST_LEN / 2);
	mpMultiply(w, u, v, TEST_LEN / 2);

	/* q = w / v, r = w % v */
	mpDivide(q, r, w, TEST_LEN, v, TEST_LEN / 2);
	/* Check q == u and r == 0 */
	assert(mpEqual(q, u, TEST_LEN / 2));
	assert(mpIsZero(r, TEST_LEN / 2));

	ClearAll();
	
	/* Pick two random numbers u, v */
	MakeMultipleRandom(u, TEST_LEN);
	MakeMultipleRandom(v, TEST_LEN);
	/* Divide one by the other: q = u / v, r = u % v */
	mpDivide(q, r, u, TEST_LEN, v, TEST_LEN);
	/* Check w = q * v + r == u */
	mpMultiply(w, q, v, TEST_LEN);
	mpAdd(w, w, r, TEST_LEN);
	assert(mpEqual(w, u, TEST_LEN));
	printf("Multiply and divide worked OK\n");

	/* ---- Greatest Common Divisor ---- */
	/* Pick 3x random primes p1, p2, p3 */
	printf("Creating 3 prime numbers (be patient):\n");
	MakeMultiplePrime(p1, TEST_LEN / 2);
	printf("(1)\n");
	MakeMultiplePrime(p2, TEST_LEN / 2);
	printf("(2)\n");
	MakeMultiplePrime(p3, TEST_LEN / 2);
	printf("(3)\n");

	/* Calculate two products from these primes */
	/* u = p1 * p2 */
	mpMultiply(u, p1, p2, TEST_LEN / 2);
	/* v = p1 * p3 */
	mpMultiply(v, p1, p3, TEST_LEN / 2);
	/* Now calculate g = gcd(u, v) */
	mpGcd(g, u, v, TEST_LEN);
	/* And check that g == p1 */
	assert(mpEqual(g, p1, TEST_LEN)); 
	printf("Greatest Common Divisor worked OK\n");

	/* ---- Modular Inverse ---- */
	/* Use previous prime as modulus, v */
	mpSetEqual(v, p1, TEST_LEN);

	/* Pick a small multiplier, m */
	m = spPseudoRand(1, MAX_DIGIT);

	/* Set u = (vm - 1) */
	mpShortMult(u, v, m, TEST_LEN);
	mpShortSub(u, u, 1, TEST_LEN);

	mpModInv(w, u, v, TEST_LEN);
	/* Check that g = (w * u) mod v = 1 */
	mpModMult(g, w, u, v, TEST_LEN);
	assert((mpShortCmp(g, 1, TEST_LEN) == 0));
	printf("Modular inverse worked OK\n");

	/* For further checks do RSA calculation - see t_mpRSA.c */
	
	return 0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美老肥妇做.爰bbww视频| 国产精品国产三级国产aⅴ原创| 一本色道久久综合亚洲91| 国产a视频精品免费观看| 国产高清成人在线| 高清不卡在线观看| 成人自拍视频在线观看| 成人小视频在线| www.99精品| 色一情一伦一子一伦一区| 一本到一区二区三区| 在线这里只有精品| 欧美三级韩国三级日本三斤| 欧美日韩国产高清一区二区三区| 欧美日韩一区二区欧美激情| 欧美美女视频在线观看| 欧美高清激情brazzers| 欧美一区二区精品在线| 日韩视频在线你懂得| 精品福利视频一区二区三区| 国产日韩欧美一区二区三区乱码 | 欧美三级资源在线| 欧美日韩国产免费| 日韩欧美一卡二卡| 久久综合九色综合97婷婷 | 国产伦精品一区二区三区视频青涩| 久久99精品久久久久久国产越南| 国产一区二区成人久久免费影院| 国产河南妇女毛片精品久久久 | 在线观看视频一区二区| 欧美日韩午夜精品| 日韩视频免费观看高清完整版在线观看 | 中文字幕一区二区三区精华液 | 国产成人av电影在线观看| 懂色av一区二区三区免费看| 99久久er热在这里只有精品15 | 国产精品久久午夜夜伦鲁鲁| 亚洲品质自拍视频| 三级久久三级久久久| 久久超碰97中文字幕| 成人美女在线观看| 欧美日韩一级二级三级| 久久影院电视剧免费观看| 亚洲视频中文字幕| 日韩av不卡一区二区| 国产精品一二三在| 欧美在线一区二区三区| 精品蜜桃在线看| 亚洲免费在线观看视频| 青青草国产精品97视觉盛宴| 成人小视频在线| 7777精品伊人久久久大香线蕉完整版| 久久久久国产精品麻豆ai换脸 | 久久久久久久久蜜桃| 亚洲精品免费电影| 精品一区二区三区免费播放| 91视频在线观看| 日韩亚洲国产中文字幕欧美| 国产精品白丝在线| 另类小说视频一区二区| 国产欧美综合在线观看第十页| 天天综合天天做天天综合| 激情成人午夜视频| 日本丰满少妇一区二区三区| 欧美大片顶级少妇| 亚洲乱码日产精品bd| 狠狠网亚洲精品| 精品视频资源站| 国产精品乱人伦中文| 秋霞午夜av一区二区三区| 一本色道久久综合狠狠躁的推荐| 精品国产一区a| 午夜精品久久久久久久久| 99久久国产免费看| 久久精品在这里| 免费的国产精品| 欧美丝袜第三区| 亚洲欧美一区二区不卡| 国产黄色精品视频| 精品少妇一区二区三区在线视频| 亚洲福利一二三区| 色综合久久天天| 国产精品久久久久久久久久免费看| 九九热在线视频观看这里只有精品| 91国偷自产一区二区三区观看 | 91精品国产综合久久久蜜臀粉嫩 | 国产高清亚洲一区| 日韩视频免费观看高清完整版在线观看 | 日韩午夜激情电影| 亚洲午夜久久久| 色综合天天综合狠狠| 亚洲国产成人在线| 国产福利91精品| 久久精品一二三| 黑人巨大精品欧美黑白配亚洲| 欧美一级高清片| 日韩成人精品在线观看| 欧美日韩国产另类一区| 亚洲一区二区三区四区中文字幕| 97久久超碰精品国产| 中文字幕一区二区日韩精品绯色| 国产精品一区二区你懂的| 精品88久久久久88久久久| 久久se精品一区二区| 欧美大度的电影原声| 久久se这里有精品| 精品国产电影一区二区| 国内不卡的二区三区中文字幕| 精品黑人一区二区三区久久 | 91丝袜国产在线播放| 国产精品国产自产拍高清av| 成人av动漫网站| 亚洲色图丝袜美腿| 91美女片黄在线| 亚洲国产一区二区视频| 欧美日韩三级视频| 日本视频中文字幕一区二区三区 | 国产精品自拍一区| 国产午夜亚洲精品理论片色戒 | 色美美综合视频| 一区二区三区中文字幕电影| 欧洲精品在线观看| 日韩黄色免费电影| 精品国产在天天线2019| 国产白丝精品91爽爽久久 | 免费成人在线网站| 精品欧美乱码久久久久久1区2区| 国产一区二区不卡| 国产精品久久久久7777按摩| 色综合久久久久综合| 午夜视频久久久久久| 日韩视频免费观看高清完整版在线观看| 久久99九九99精品| 中文字幕高清一区| 在线观看视频91| 久久精品国产在热久久| 日本一区二区视频在线| 色88888久久久久久影院按摩| 天堂在线亚洲视频| 亚洲精品一区在线观看| 成人黄色777网| 亚洲成人动漫av| 久久夜色精品国产噜噜av| 99久久精品情趣| 日韩二区三区在线观看| 国产三级三级三级精品8ⅰ区| 色94色欧美sute亚洲线路二| 日韩一区精品视频| 中文字幕欧美日本乱码一线二线| 日本精品一级二级| 精品中文av资源站在线观看| 中文字幕一区二区三区视频| 51午夜精品国产| 成人网在线播放| 日本欧美大码aⅴ在线播放| 欧美激情一区二区三区不卡 | 欧美一区二区三区性视频| 国产精品一区在线| 亚洲一区中文日韩| 国产日本欧美一区二区| 欧美日韩一区小说| 豆国产96在线|亚洲| 日韩高清国产一区在线| 中文字幕一区视频| 亚洲女子a中天字幕| 日韩精品最新网址| 日本乱人伦aⅴ精品| 国产成人综合在线观看| 石原莉奈在线亚洲三区| 国产精品色在线观看| 欧美一级视频精品观看| 日本乱人伦一区| 成人综合在线视频| 精品一区二区三区久久| 亚洲在线观看免费| 中文字幕一区三区| 久久久久久久综合狠狠综合| 欧美久久久久久久久久| 91片黄在线观看| 国产精品一区2区| 日本不卡视频在线观看| 亚洲精品高清在线观看| 中文字幕av不卡| 久久蜜桃av一区精品变态类天堂 | 精品国产一区二区在线观看| 欧美日韩免费在线视频| 91蝌蚪porny| 成人sese在线| 国产福利电影一区二区三区| 久久国产生活片100| 日本伊人色综合网| 五月激情综合网| 亚洲一区二区精品3399| 亚洲欧美偷拍卡通变态| 亚洲欧美在线观看| 欧美—级在线免费片| 国产日韩精品一区二区三区| 精品国产一区二区三区久久久蜜月 | 久久嫩草精品久久久精品一| 日韩小视频在线观看专区|