Марат Радченко (slonopotamus) wrote,
Марат Радченко
slonopotamus

Category:

Оптимизации птсо

Есть программка. Мне сказали что она делает решето Эратосфена, но на самом деле это не важно.

int main()
{
    int n = 500000000;
    int *a = new int[n + 1];

    for (int i = 0; i <= n; i++)
    {
        a[i] = i;
    }

    for (int i = 2; i * i <= n; i++)
    {
        if (a[i])
        {
            for (int j = i * i; j <= n; j += i)
            {
                a[j] = 0;
            }
        }        
    }

    delete[] a;
    return 0;
}


Вопрос. Почему ни gcc ни clang даже под -O3 не понимают что это всё можно упростить до return 0; т.к. результат вычислений никуда не используется? Пробовал заменять new/delete на аллокацию на стэке, не помогает.

Update: в GCC был баг, но теперь его починили и ВЖУХ он оптимизирует весь этот код вникуда.
Tags: c++
Subscribe

  • (no subject)

    Прекрасное (без шуток) начало рабочего дня. Комп меня встретил вот таким окном:

  • (no subject)

    4,692,251,770 байт - объём dvd-диска 4,989,841,408 байт - размер iso с windows 10 С флешки материнка грузиться не умеет Ищу цензурных слов и не…

  • Гугл-переводчик в 2020-ом году

    Предыдущий выпуск Что означает надпись "Язык оригинала: китайский" и как это согласуется с "Английский (определён…

  • Post a new comment

    Error

    default userpic

    Your reply will be screened

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 24 comments