⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 t-cmp_si.c

📁 a very popular packet of cryptography tools,it encloses the most common used algorithm and protocols
💻 C
字号:
/* Test mpz_cmp_si.Copyright 2000, 2001 Free Software Foundation, Inc.This file is part of the GNU MP Library.The GNU MP Library is free software; you can redistribute it and/or modifyit under the terms of the GNU Lesser General Public License as published bythe Free Software Foundation; either version 2.1 of the License, or (at youroption) any later version.The GNU MP Library is distributed in the hope that it will be useful, butWITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITYor FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General PublicLicense for more details.You should have received a copy of the GNU Lesser General Public Licensealong with the GNU MP Library; see the file COPYING.LIB.  If not, write tothe Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,MA 02111-1307, USA. */#include <stdio.h>#include <stdlib.h>#include "gmp.h"#include "gmp-impl.h"#include "tests.h"#define SGN(x)       ((x) < 0 ? -1 : (x) == 0 ? 0 : 1)voidcheck_data (void){  static const struct {    const char  *a, *b;    int         want;  } data[] = {    { "0",  "1", -1 },    { "0",  "0",  0 },    { "0", "-1",  1 },    { "1",  "1", 0 },    { "1",  "0", 1 },    { "1", "-1", 1 },    { "-1",  "1", -1 },    { "-1",  "0", -1 },    { "-1", "-1", 0 },    {           "0", "-0x80000000",  1 },    {  "0x80000000", "-0x80000000",  1 },    {  "0x80000001", "-0x80000000",  1 },    { "-0x80000000", "-0x80000000",  0 },    { "-0x80000001", "-0x80000000", -1 },    {                   "0", "-0x8000000000000000",  1 },    {  "0x8000000000000000", "-0x8000000000000000",  1 },    {  "0x8000000000000001", "-0x8000000000000000",  1 },    { "-0x8000000000000000", "-0x8000000000000000",  0 },    { "-0x8000000000000001", "-0x8000000000000000", -1 },  };  mpz_t  a, bz;  long   b;  int    got;  int    i;  mpz_init (a);  mpz_init (bz);  for (i = 0; i < numberof (data); i++)    {      mpz_set_str_or_abort (a, data[i].a, 0);      mpz_set_str_or_abort (bz, data[i].b, 0);      if (mpz_fits_slong_p (bz))        {          b = mpz_get_si (bz);          got = mpz_cmp_si (a, b);          if (SGN (got) != data[i].want)            {              printf ("mpz_cmp_si wrong on data[%d]\n", i);              printf ("  a="); mpz_out_str (stdout, 10, a); printf ("\n");              printf ("  b=%ld\n", b);              printf ("  got=%d\n", got);              printf ("  want=%d\n", data[i].want);              abort();                                                }        }    }  mpz_clear (a);  mpz_clear (bz);}intmain (void){  tests_start ();  check_data ();  tests_end ();  exit (0);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -