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

📄 hilbertpoly.c

📁 这是一个C的源代码
💻 C
字号:
// Prints Hilbert polynomial H_D(X)// D is the first argument on the command-line// If no D is specified, set D = 3#include <stdio.h>#include <stdlib.h> //for atoi, exit#include <gmp.h>#include "pbc_field.h"#include "pbc_darray.h"#include "pbc_poly.h"#include "pbc_hilbert.h"int main(int argc, char **argv){    int n;    int i;    int D = 3;    darray_t coefflist;    void xpow(int degree) {	if (degree == 1) {	    printf("X");	} else if (degree) {	    printf("X^%d", degree);	}    }    if (argc > 1) {	int m;	D = atoi(argv[1]);	m = D % 4;	if (D <= 0 || m == 1 || m == 2) {	    fprintf(stderr, "D must be 0 or 3 mod 4 and positive\n");	    exit(1);	}    }    printf("D = %d\n", D);    darray_init(coefflist);    hilbert_poly(coefflist, D);    n = coefflist->count;    printf(" ");    xpow(n - 1);    printf("\n");    for (i=n-2; i>=0; i--) {	if (mpz_sgn((mpz_ptr) coefflist->item[i]) >= 0) {	    printf("+");	}	mpz_out_str(stdout, 0, coefflist->item[i]);	xpow(i);	printf("\n");    }    return 0;}

⌨️ 快捷键说明

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