169 похожих чатов

#Include <stdlib.h> #include <stdio.h> #include <math.h> #include <assert.h> #include <limits.h> long long avg3(long long a,

long long b, long long c)
{
if (a == b && b == c)
{
return a;
}

if (llabs(a) >= 9223372036854775800 || llabs(b) >= 9223372036854775800 || llabs(c) >= 9223372036854775800)
{
lldiv_t A = lldiv(a, 3);
lldiv_t B = lldiv(b, 3);
lldiv_t C = lldiv(c, 3);

printf("A %lld %lld\n", A.quot, A.rem);
printf("B %lld %lld\n", B.quot, B.rem);
printf("C %lld %lld\n", C.quot, C.rem);

A.rem = A.rem != 0? a - A.rem: 0;
B.rem = B.rem != 0? b - B.rem: 0;
C.rem = C.rem != 0? c - C.rem: 0;

size_t size;

size = snprintf(NULL, 0, "%lld", A.rem) + 1;
char *Arem = calloc(1, size);
sprintf(Arem, "%lld", A.rem);

size = snprintf(NULL, 0, "%lld", B.rem) + 1;
char *Brem = calloc(1, size);
sprintf(Brem, "%lld", B.rem);

size = snprintf(NULL, 0, "%lld", C.rem) + 1;
char *Crem = calloc(1, size);
sprintf(Crem, "%lld", C.rem);

A.rem >= 0? sscanf(Arem, "%1lld", &A.rem) : sscanf(Arem, "%2lld", &A.rem);
B.rem >= 0? sscanf(Brem, "%1lld", &B.rem) : sscanf(Brem, "%2lld", &B.rem);
C.rem >= 0? sscanf(Crem, "%1lld", &C.rem) : sscanf(Crem, "%2lld", &C.rem);

free(Arem), free(Brem), free(Crem);

printf("TEST %lld\n", A.rem);
printf("TEST %lld\n", B.rem);
printf("TEST %lld\n", C.rem);

A.rem >= 5? A.quot++ : 0;
B.rem >= 5? B.quot++ : 0;
C.rem >= 5? C.quot++ : 0;

A.rem <= -5? A.quot-- : 0;
B.rem <= -5? B.quot-- : 0;
C.rem <= -5? C.quot-- : 0;

printf("A %lld %lld\n", A.quot, A.rem);
printf("B %lld %lld\n", B.quot, B.rem);
printf("C %lld %lld\n", C.quot, C.rem);

long long res = A.quot + B.quot + C.quot;

printf("%lld\n", res);

return res;
}
else
{
long double average = (long double)(a + b + c) / 3.0;

printf("%lf\n", average);

return truncl(average);
}

}

int main()
{
assert(avg3(1, 2, 3) == 2);
assert(avg3(100, -100, 30) == 10);
assert(avg3(1, 2, 2) == 1);
assert(avg3(-1, -2, -2) == -1);
assert(avg3(LLONG_MAX, LLONG_MAX, LLONG_MAX) == LLONG_MAX);
assert(avg3(9223372036854775800, 9223372036854775800, -8) == 6148914691236517197);
assert(avg3(-7653464028037849600, 0, 0) == -2551154676012616533);
assert(avg3(7653464028037849600, 0, 0) == 2551154676012616533);
assert(avg3(9223372036854775800, -4611686018427387912, -4611686018427387911) == -7);
assert(avg3(-9223372036854775800, 4611686018427387912, 4611686018427387911) == 7);
}

4 ответов

30 просмотров

что это

это что за тест компилятора СИ

Ахуенно

Уважаемый, зачем вы написали этот кринж? Вы же понимаете, что мало того, что код отвратителен и не привязан к константам limits.h, так ещё у вас присутствует переполнение знакового инта, возможная потеря точности от каста и куча бесполезных действий?

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта