#include <stdio.h>
#include <math.h>
#include <string.h>
#include <stdlib.h>
#include <stdint.h>
void print_int128(__int128_t value);
void print_uint128(__uint128_t value);
__int128_t str_to_int128(const char *str);
__int128_t abs128(__int128_t x);
void zero(char* text, size_t size);
void bitcounter(int b, char* text, __int128_t y);
char* binary(__int128_t x);
int main(void)
{
//FILE* filePtr;
//filePtr = freopen("Output.txt", "w", stdout);
size_t t=0;
char input[500];
char text[10];
char number[50];
int b;
//long long int x;
zero(input, sizeof(input));
zero(number, sizeof(number));
fgets(input
, sizeof(input
), stdin
);
for(size_t i=0; i<t; i++)
{
zero(input, sizeof(input));
zero(number, sizeof(number));
zero(text, sizeof(text));
b = 0;
//x = 0;
fgets(input
, sizeof(input
), stdin
); sscanf(input
, "%d %s %s", &b
, text
, number
);
if (number[len - 1] == '\n')
{
number[len - 1] = '\0';
}
__int128_t x = str_to_int128(number);
bitcounter(b, text, x);
}
//fclose(filePtr);
return 0;
}
void zero(char* text, size_t size)
{
for(size_t i=0; i<size; i++)
{
text[i] = '\0';
}
}
void bitcounter(int b, char* text, __int128_t y)
{
__int128_t x = y;
__int128_t full64signed = 9223372036854775808ULL;
__int128_t full64unsigned = 18446744073709551615ULL;
char value[129];
zero(value, sizeof(value));
char* binaryPtr;
if(strcmp(text
, "SIGNED") == 0 && x
<0) {binaryPtr
= binary
(abs128
(y
)-1);} else {binaryPtr = binary(abs128(y));}
//printf("binaryPtr: %s\n", binaryPtr);
//printf("value: %s\n", value);
char fin[129];
zero(fin, sizeof(fin));
//printf("fin: %s\n", fin);
if(strcmp(text
, "SIGNED") == 0) {
if(x<0)
{
if(b == 2)
{
if(x
< -2) {printf("-2 1 Ups\n");} else if(x
== -1) {printf("-2 1 10\n");} else if(x
== -2) {printf("-2 1 11\n");} }
else if(b == 3)
{
if(x
< -4) {printf("-4 3 Ups\n");} else if(x
== -1) {printf("-4 3 1%s\n", &fin
[1]);} else {printf("-4 3 1%s\n", &fin
[1]);} }
else if(b > 3 && b < 64)
{
unsigned long long int minimum = (long double)powl(2,b-1);
unsigned long long int maximum = (long double)powl(2,b-1)-1;
__int128_t xu = abs128(x);
if(xu
> (long double)powl
(2,b
-1)) {printf("-%llu %llu Ups\n", minimum
, maximum
);} else {printf("-%llu %llu 1%s\n", minimum
, maximum
, &fin
[1]);} }
else
{
unsigned long long int minimum = (long double)powl(2,b-1);
unsigned long long int maximum = (long double)powl(2,b-1)-1;
__int128_t xu = abs128(x);
if(xu
> (long double)powl
(2,b
-1) || xu
> full64signed
) {printf("-%llu %llu Ups\n", minimum
, maximum
);} else {printf("-%llu %llu 1%s\n", minimum
, maximum
, &fin
[1]);} }
}
else
{
if(b == 2)
{
if(x
>1) {printf("-2 1 Ups\n");} else if(x
== 0) {printf("-2 1 00\n");} else if(x
== 1) {printf("-2 1 01\n");} }
else if(b == 3)
{
if(x
> 3) {printf("-4 3 Ups\n");} else {printf("-4 3 %s\n", fin
);} }
else
{
unsigned long long int minimum = (long double)powl(2,b-1);
unsigned long long int maximum = (long double)powl(2,b-1)-1;
__uint128_t xu = abs128(x);
__uint128_t maxValue = ((__uint128_t)1 << b) - 1;
if(xu
> (long double)(powl
(2, b
-1))-1 || xu
> maxValue
) {printf("-%llu %llu Ups\n", minimum
, maximum
);} else {printf("-%llu %llu %s\n", minimum
, maximum
, fin
);} }
}
}
else if(strcmp(text
, "UNSIGNED") == 0) {
if(b == 0)
{
}
else if(b == 1)
{
if(x
>1) {printf("0 1 Ups\n");} else if(x
== 1) {printf("0 1 1\n");} else if(x
== 0) {printf("0 1 0\n");} }
else if(b == 2)
{
if(x
>3) {printf("0 3 Ups\n");} }
else
{
unsigned long long int maximum = (long double)powl(2,b)-1;
__uint128_t xu = abs128(x);
if(xu
> (long double)powl
(2,b
) || xu
> full64unsigned
|| x
<0) {printf("0 %llu Ups\n", maximum
);} else {printf("0 %llu %s\n", maximum
, fin
);} }
}
}
char* binary(__int128_t x)
{
char* result
= (char*)malloc(129 * sizeof(char)); // 128 bitów + 1 dla '\0' if (!result)
{
fprintf(stderr
, "Memory allocation failed\n"); }
result[128] = '\0';
for (int i = 127; i >= 0; i--) {
result[i] = (x & 1) ? '1' : '0';
x >>= 1;
}
return result;
}
void print_int128(__int128_t value)
{
if (value == 0)
{
return;
}
char buffer[40];
int i = 39;
buffer[i] = '\0';
i--;
int negative = 0;
if (value < 0)
{
negative = 1;
value = -value;
}
while (value > 0)
{
buffer[i] = '0' + (value % 10);
value /= 10;
i--;
}
if (negative)
{
buffer[i] = '-';
i--;
}
}
__int128_t str_to_int128(const char *str)
{
__int128_t result = 0;
int sign = 1;
if (*str == '-')
{
sign = -1;
str++;
}
while (*str)
{
result = result * 10 + (*str - '0');
str++;
}
return sign * result;
}
__int128_t abs128(__int128_t x)
{
return (x < 0) ? -x : x;
}
void print_uint128(__uint128_t value)
{
if (value == 0)
{
return;
}
char buffer[40]; // 128-bitowa liczba całkowita zmieści się w maksymalnie 39 cyfrach dziesiętnych
int i = 39;
buffer[i] = '\0';
i--;
while (value > 0)
{
buffer[i] = '0' + (value % 10);
value /= 10;
i--;
}
}
#include <stdio.h>
#include <math.h>
#include <string.h>
#include <stdlib.h>
#include <stdint.h>

void print_int128(__int128_t value);
void print_uint128(__uint128_t value);
__int128_t str_to_int128(const char *str);
__int128_t abs128(__int128_t x);
void zero(char* text, size_t size);
void bitcounter(int b, char* text, __int128_t y);
char* binary(__int128_t x);

int main(void)
{
    //FILE* filePtr;
    //filePtr = freopen("Output.txt", "w", stdout);

    size_t t=0;
    char input[500];
    char text[10];
    char number[50];
    int b;
    //long long int x;

    zero(input, sizeof(input));
    zero(number, sizeof(number));
    fgets(input, sizeof(input), stdin);
    sscanf(input, "%zu", &t);

    for(size_t i=0; i<t; i++)
    {
        zero(input, sizeof(input));
        zero(number, sizeof(number));
        zero(text, sizeof(text));
        b = 0;
        //x = 0;

        fgets(input, sizeof(input), stdin);
        sscanf(input, "%d %s %s", &b, text, number);

        size_t len = strlen(number);
        if (number[len - 1] == '\n') 
        {
            number[len - 1] = '\0';
        }

        __int128_t x = str_to_int128(number);

        bitcounter(b, text, x);
    }

    //fclose(filePtr);
    return 0;
}

void zero(char* text, size_t size)
{
    for(size_t i=0; i<size; i++)
    {
        text[i] = '\0';
    }
}

void bitcounter(int b, char* text, __int128_t y)
{
    __int128_t x = y;
    __int128_t full64signed = 9223372036854775808ULL;
    __int128_t full64unsigned = 18446744073709551615ULL;
    char value[129];
    zero(value, sizeof(value));

    char* binaryPtr;
    if(strcmp(text, "SIGNED") == 0 && x<0) {binaryPtr = binary(abs128(y)-1);}
    else {binaryPtr = binary(abs128(y));}
    //printf("binaryPtr: %s\n", binaryPtr);
    strcpy(value, binaryPtr);
    //printf("value: %s\n", value);
    free(binaryPtr);

    char fin[129];
    zero(fin, sizeof(fin));

    sprintf(fin, "%s", &value[128-b]);
    //printf("fin: %s\n", fin);

    if(strcmp(text, "SIGNED") == 0)
    {
        if(x<0)
        {
            if(b == 2)
            {
                if(x < -2) {printf("-2 1 Ups\n");}
                else if(x == -1) {printf("-2 1 10\n");}
                else if(x == -2) {printf("-2 1 11\n");}
            }
            else if(b == 3)
            {
                if(x < -4) {printf("-4 3 Ups\n");}
                else if(x == -1) {printf("-4 3 1%s\n", &fin[1]);}
                else {printf("-4 3 1%s\n", &fin[1]);}
            }
            else if(b > 3 && b < 64)
            {
                unsigned long long int minimum = (long double)powl(2,b-1);
                unsigned long long int maximum = (long double)powl(2,b-1)-1;
                __int128_t xu = abs128(x);
                if(xu > (long double)powl(2,b-1)) {printf("-%llu %llu Ups\n", minimum, maximum);}
                else {printf("-%llu %llu 1%s\n", minimum, maximum, &fin[1]);}
            }
            else
            {
                unsigned long long int minimum = (long double)powl(2,b-1);
                unsigned long long int maximum = (long double)powl(2,b-1)-1;
                __int128_t xu = abs128(x);
                if(xu > (long double)powl(2,b-1) || xu > full64signed) {printf("-%llu %llu Ups\n", minimum, maximum);}
                else {printf("-%llu %llu 1%s\n", minimum, maximum, &fin[1]);}
            }
        }
        else
        {
            if(b == 2)
            {
                if(x>1) {printf("-2 1 Ups\n");}
                else if(x == 0) {printf("-2 1 00\n");}
                else if(x == 1) {printf("-2 1 01\n");}
            }
            else if(b == 3)
            {
                if(x > 3) {printf("-4 3 Ups\n");}
                else {printf("-4 3 %s\n", fin);}
            }
            else
            {
                unsigned long long int minimum = (long double)powl(2,b-1);
                unsigned long long int maximum = (long double)powl(2,b-1)-1;
                __uint128_t xu = abs128(x);
                __uint128_t maxValue = ((__uint128_t)1 << b) - 1;
                if(xu > (long double)(powl(2, b-1))-1 || xu > maxValue) {printf("-%llu %llu Ups\n", minimum, maximum);}
                else {printf("-%llu %llu %s\n", minimum, maximum, fin);}
            }
        }
    }
    else if(strcmp(text, "UNSIGNED") == 0)
    {
        if(b == 0)
        {
            printf("0 0 Ups\n");
        }
        else if(b == 1)
        {
            if(x>1) {printf("0 1 Ups\n");}
            else if(x == 1) {printf("0 1 1\n");}
            else if(x == 0) {printf("0 1 0\n");}
        }
        else if(b == 2)
        {
            if(x>3) {printf("0 3 Ups\n");}
            else printf("0 3 %s\n", fin);
        }
        else
        {
            unsigned long long int maximum = (long double)powl(2,b)-1;
            __uint128_t xu = abs128(x);
            if(xu > (long double)powl(2,b) || xu > full64unsigned || x<0) {printf("0 %llu Ups\n", maximum);}
            else {printf("0 %llu %s\n", maximum, fin);}
        }
    }
}

char* binary(__int128_t x) 
{
    char* result = (char*)malloc(129 * sizeof(char)); // 128 bitów + 1 dla '\0'
    if (!result) 
    {
        fprintf(stderr, "Memory allocation failed\n");
        exit(EXIT_FAILURE);
    }

    result[128] = '\0';

    for (int i = 127; i >= 0; i--) {
        result[i] = (x & 1) ? '1' : '0';
        x >>= 1;
    }

    return result;
}

void print_int128(__int128_t value) 
{
    if (value == 0) 
    {
        printf("0");
        return;
    }

    char buffer[40];
    int i = 39;
    buffer[i] = '\0';
    i--;

    int negative = 0;
    if (value < 0) 
    {
        negative = 1;
        value = -value;
    }

    while (value > 0) 
    {
        buffer[i] = '0' + (value % 10);
        value /= 10;
        i--;
    }

    if (negative) 
    {
        buffer[i] = '-';
        i--;
    }

    printf("%s", &buffer[i + 1]);
}

__int128_t str_to_int128(const char *str) 
{
    __int128_t result = 0;
    int sign = 1;

    if (*str == '-') 
    {
        sign = -1;
        str++;
    }

    while (*str) 
    {
        result = result * 10 + (*str - '0');
        str++;
    }

    return sign * result;
}

__int128_t abs128(__int128_t x) 
{
    return (x < 0) ? -x : x;
}

void print_uint128(__uint128_t value) 
{
    if (value == 0) 
    {
        printf("0");
        return;
    }

    char buffer[40]; // 128-bitowa liczba całkowita zmieści się w maksymalnie 39 cyfrach dziesiętnych
    int i = 39;
    buffer[i] = '\0';
    i--;

    while (value > 0) 
    {
        buffer[i] = '0' + (value % 10);
        value /= 10;
        i--;
    }

    printf("%s", &buffer[i + 1]);
}
