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 ответов

21 просмотр

что это

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

Ахуенно

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

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
function LoadMemoryFromInet2( f:TMemoryStream; const url:string; var e:string ):Boolean; var http:TIdHttp; LHandler: TIdSSLIOHandlerSocketOpenSSL;begin Result := fals...
Александр Смоляков
1
Я вот подумал. SSE выполняет операции максимум с 64-битной точностью. А FPU - всегда с 80-битной. Разве не должно быть FPU точнее тогда?
The Bird of Hermes
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
как быть с принтером? такой подход прокатит?
zamtmn
12
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Карта сайта