blob: 086239ae0a8642c8bef56594660df55a6d73628e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
#include "bc.h"
#include <math.h>
#include <stdlib.h>
#include <stdio.h>
bc_num zero;
bc_num *bc_new(const char *str)
{
if (str == NULL) {
return &zero;
}
bc_num *num = calloc(1, sizeof(*num));
num->n = atoi(str);
return num;
}
int bc_toint(bc_num *num)
{
return num->n;
}
bc_num *bc_print(bc_num *num)
{
printf("%"PRIdMAX"\n", num->n);
return num;
}
bc_num *bc_length(bc_num *a)
{
return a;
}
bc_num *bc_sqrt(bc_num *a)
{
bc_num *root = calloc(1, sizeof(*root));
root->n = sqrt(a->n);
return root;
}
bc_num *bc_scale(bc_num *a)
{
return a;
}
void bc_free(bc_num *n)
{
free(n);
}
|