4 typedef long long int ll_t;
5 typedef unsigned long long int ull_t;
8 ll_t mul_ll(ll_t a, ll_t b) __attribute__((noinline));
9 ll_t shl_ll(ll_t a, ll_t b) __attribute__((noinline));
10 ll_t shr_ll(ll_t a, ll_t b) __attribute__((noinline));
11 ll_t add_ll(ll_t a, ll_t b) __attribute__((noinline));
12 ll_t sub_ll(ll_t a, ll_t b) __attribute__((noinline));
13 ll_t div_ll(ll_t a, ll_t b) __attribute__((noinline));
14 ll_t mod_ll(ll_t a, ll_t b) __attribute__((noinline));
15 ll_t divmod_ll(ll_t a, ll_t b) __attribute__((noinline));
16 ll_t abs_ll(ll_t a) __attribute__((noinline));
17 ll_t neg_ll(ll_t a) __attribute__((noinline));
19 ull_t mul_ull(ull_t a, ull_t b) __attribute__((noinline));
20 ull_t shl_ull(ull_t a, ull_t b) __attribute__((noinline));
21 ull_t shr_ull(ull_t a, ull_t b) __attribute__((noinline));
22 ull_t add_ull(ull_t a, ull_t b) __attribute__((noinline));
23 ull_t sub_ull(ull_t a, ull_t b) __attribute__((noinline));
24 ull_t div_ull(ull_t a, ull_t b) __attribute__((noinline));
25 ull_t mod_ull(ull_t a, ull_t b) __attribute__((noinline));
26 ull_t divmod_ull(ull_t a, ull_t b) __attribute__((noinline));
27 ull_t abs_ull(ull_t a) __attribute__((noinline));
28 ull_t neg_ull(ull_t a) __attribute__((noinline));
31 ll_t mul_ll(ll_t a, ll_t b) {
35 ll_t shl_ll(ll_t a, ll_t b) {
39 ll_t shr_ll(ll_t a, ll_t b) {
43 ll_t add_ll(ll_t a, ll_t b) {
47 ll_t sub_ll(ll_t a, ll_t b) {
51 ll_t div_ll(ll_t a, ll_t b) {
55 ll_t mod_ll(ll_t a, ll_t b) {
59 ll_t divmod_ll(ll_t a, ll_t b) {
60 return (a / b) + (a % b);
72 double conv_ll_d(ll_t a) {
76 ll_t conv_d_ll(double a) {
83 ull_t mul_ull(ull_t a, ull_t b) {
87 ull_t shl_ull(ull_t a, ull_t b) {
91 ull_t shr_ull(ull_t a, ull_t b) {
95 ull_t add_ull(ull_t a, ull_t b) {
99 ull_t sub_ull(ull_t a, ull_t b) {
103 ull_t div_ull(ull_t a, ull_t b) {
107 ull_t mod_ull(ull_t a, ull_t b) {
111 ull_t divmod_ull(ull_t a, ull_t b) {
112 return (a / b) + (a % b);
115 ull_t neg_ull(ull_t a) {
119 ull_t abs_ull(ull_t a) {
124 double conv_ull_d(ull_t a) {
128 ull_t conv_d_ull(double a) {
135 ll_t b = 0x123456789;
136 ll_t c = 0x8001023000002460;
137 double d = (double)c;
140 ull_t ub = 0x123456789;
141 ull_t uc = 0x8001023000002460;
143 printf("%lld * %lld = %lld\n", a, b, mul_ll(a, b));
144 printf("%lld + %lld = %lld\n", a, b, add_ll(a, b));
145 printf("%lld - %lld = %lld\n", a, b, sub_ll(a, b));
146 printf("%lld / %lld = %lld\n", b, a, div_ll(b, a));
147 printf("%lld %% %lld = %lld\n", b, a, mod_ll(b, a));
148 printf("%lld / + %% %lld = %lld\n", b, a, divmod_ll(b, a));
149 printf("%lld << %d = %lld\n", a, 2, shl_ll(a, 2));
150 printf("%lld >> %d = %lld\n", a, 2, shr_ll(a, 2));
151 printf("abs(%lld) = %lld\n", c, abs_ll(c));
152 printf("neg(%lld) = %lld\n", b, neg_ll(b));
154 printf("conv(%lld) = %lf\n", c, conv_ll_d(c));
155 printf("conv(%lf) = %lld\n", d, conv_d_ll(d));
158 printf("%llu * %llu = %llu\n", ua, ub, mul_ull(ua, ub));
159 printf("%llu + %llu = %llu\n", ua, ub, add_ull(ua, ub));
160 printf("%llu - %llu = %llu\n", ua, ub, sub_ull(ua, ub));
161 printf("%llu / %llu = %llu\n", ub, ua, div_ull(ub, ua));
162 printf("%llu %% %llu = %llu\n", ub, ua, mod_ull(ub, ua));
163 printf("%llu / + %% %llu = %llu\n", ub, ua, divmod_ull(ub, ua));
164 printf("%llu << %d = %llu\n", ua, 2, shl_ull(ua, 2));
165 printf("%llu >> %d = %llu\n", ua, 2, shr_ull(ua, 2));
166 printf("abs(%llu) = %llu\n", uc, abs_ull(uc));
167 printf("neg(%llu) = %llu\n", ub, neg_ull(ub));
169 printf("conv(%llu) = %lf\n", uc, conv_ull_d(uc));
170 printf("conv(%lf) = %llu\n", d, conv_d_ull(d));