1. Pascal / Говнокод #7178

    +98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    function Prime (N: longword): boolean;
    var
    	i : longword;
    	Max : single;
    begin
    	if N = 2
    		then Prime := true
    	else if (N <= 1) or (N mod 2 = 0)
    		then Prime := false
    	else begin
    		Prime := true;
    		i := 3; Max := sqrt(N);
    		while i <= Max do begin
    			if N mod i = 0 then begin
    				Prime := false; 
    				exit
    			end;
    			i := i + 2
    		end
    	end
    end;
    
    var
    	a, i : longword;
    
    begin
    	read(a);
    	for i := 2 to a do
    		if Prime(i)
    			then writeln(i, ' is a prime number');
    end.

    Нахождение простых чисел.

    Запостил: sunshinelf, 06 Июля 2011

    Комментарии (29) RSS

    • >i := 3; Max := sqrt(N); //считаем до корня
      >i := i + 2 //нечетные
      >Prime := false; exit //прерывание цикла

      м-м-м довольно неплохо.
      как по мне довольно адекватная и чуть ли не образцовая (как для лабы) реализация.
      Ответить
    • Да, что постер не осилил в этом приличном школьном примере?
      Ответить
    • Если задача была в поиске всех простых чисел, можно было сэкономить храня числа в массиве вместо перебора всех нечетных. Ну и отступы в 8 пробелов режут глаз.
      Ответить
      • > можно было сэкономить храня
        лаба же
        а прикладные простые числа всё разно таким брутом нет смысла искать
        Ответить
      • зависит от того какой величины тебе нужны простые числа. решетом Эратосфена далеко даже на продвинутых системах не уедешь.

        но как бы да, это стандартная оптимизация: несколько тысяч первых простых чисел иметь под рукой в таблице. количество простых чисел то с величиной уменшается.
        Ответить
      • >Ну и отступы в 8 пробелов режут глаз.
        если попробовать выделить эти "пробелы", то они окажутся православными табами.
        и мне не режут. это лучше, чем без отступов

        >задача была в поиске всех простых чисел
        ряд простых чисел бесконечен. найти все невозможно.

        насичот остального уже сказано выше.
        Ответить
        • >ряд простых чисел бесконечен. найти все невозможно.
          Я имел в виду то, что делается в задаче. Найти все простые числа до заданного числа N. Лаба или не лаба - не важно, раз можно было найти оптимальнее.

          Отступы - не спорю, может кто-то и к 8 привык или у него автозамены табов на пробелы нет.
          Ответить
          • > найти оптимальнее
            в школах не изучают ни теорему Проклингтона, ни эллиптические кривые
            Ответить
          • а где критерий оптимальности?
            может задача была сделать с ограничением по используемой памяти.
            Ответить
      • не, отступы в 8 пробелов - это кошерно, по linux kernel coding style. а вот более 3 уровней вложенности - нет.
        Ответить
    • Говно в отступах!
      Ответить
      • >Говно в отступах!
        Не, в отступах табы.

        зы:Страйкер, пофикси гигантские табы.
        Ответить
        • это вывихи последней версии GeSHi. Тоже не знаю как это воркараундить, опция "кол-во пробелов на таб" ничего не делает

          з.ы. а может даже и не его.
          Ответить
      • Нет. Если и где есть тут говно, то только в языке Дельфи.
        Ответить
        • свинья везде грязь найдет
          Ответить
        • тролко
          Ответить
        • Не, неправильно так троллить Тараса. Не потому языку (нужна Ада) и недостаточно аргументов.
          Ответить
          • >Не потому
            Хм.
            >(нужна Ада) и недостаточно аргументов.
            Согласен.
            >троллить Тараса
            Никто его не троллит. Я высказал мнение.
            Ответить
          • Да Тарас специально выбрал такой язык, за который тяжело троллить. Дельфой то пользовались все и все её знают со всеми её недостатками, а адой не пользовались почти все, кроме Тараса. Так что Аргументы привести против Ады будет тяжело.

            А не аргументированные фразы типа Ада - говно -- вряд ли прокатят. Уныло.
            Ответить
        • Тарас уже много раз публично признавал, что дельфи - это говно и в нем много недостатков, зато Ада крута. Какой смысл троллить его по дельфе? Нужно говорить, мол Delphi/Ada - дерьмо и приводить аргументы: общие недостатки этих языков или недостатки Ады.

          Берегись Тарас!
          Ответить

    Добавить комментарий