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

    +87

    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
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    88. 88
    89. 89
    90. 90
    91. 91
    92. 92
    93. 93
    94. 94
    95. 95
    program lab_16;
     {$APPTYPE CONSOLE}
     uses
      windows,
      SysUtils;
     {#1. Дана строка, содержащая русский текст.
     Если в тексте нет слов-палиндромов длиной более 1-й буквы,
     то вывести слова текста в    соответствии с убыванием количества согласных,
     в противном    случае пpодублиpовать в словах текста гласные буквы и вывести
      полученные слова в поpядке, обpатном к алфавитному.}
      const nmax=100;
      Alf = ['А'..'Я','а'..'я'];
      rulett3 = ['А', 'Е', 'Ё', 'И', 'О', 'У', 'Ы', 'Э', 'Ю', 'Я', 'а', 'е', 'ё', 'и', 'о', 'у', 'ы', 'э', 'ю', 'я'];
     type Mas_slov=array[1..nmax] of string;
    
     procedure vvod(var a : Mas_slov; var n : integer);
     var stroka,str:string;
         i : integer;
     begin
          reset(input,'input.txt');
          read(stroka);
          str:='';
          n:=0;
          stroka:=stroka+' ';
          for i:=1 to length(stroka) do
           if stroka[i] in Alf then str:=str+stroka[i]
           else if str<>'' then begin
                 inc(n);
                 a[n]:=str;
                 str:='';
           end;
     end;
    
     function kolsog(x:string):integer;    {фунция нахождения кол-ва согл букв}
     var k,j,z:integer;
      begin
        z:=0;
        for k:=1 to length(x) do
        if not (x[k] in rulett3) then inc(z);
        kolsog:=z;
      end;
    
     function palin(x:string):boolean;     {проверка на палиндром}
     var z,i:integer;
     begin
        palin:=false;
        z:=0;
        for i:=1 to length(x) do
        if x[i]=x[length(x)+1-i] then z:=z+1;
      if z=length(x) then palin:=true;
     end;
    
     function prov(a : Mas_slov; n : integer):boolean;
     var i,j:integer;
     begin
     prov:=false;
     for i:=1 to n do
     if (length(a[i])>1) and (palin(a[i])=true) then prov:=true;
     end;
    
     procedure sort(var a:mas_slov; n: integer);
     var i,j:integer;
          st:string;
     begin
      for i:=1 to n-1 do
     for j:=i+1 to n do
     if kolsog(a[i])< kolsog(a[j]) then
     begin   st:=a[i]; a[i]:=a[j]; a[j]:=st; end;
     end;
    
     function dubl(x:string):string;  {дублирование гласных букв}
     var q:integer;
     begin
     q:=1;
     while q<>length(x)+1 do  begin
     if (x[q] in rulett3) then begin Insert(x[q],x,q); inc(q,2)end else inc(q); end;
     dubl:=x;
     end;
    
     procedure dubl2(var a:mas_slov; n:integer);
     var i:integer;
     begin
     for i:=1 to n do
     a[i]:=dubl(a[i]);
     end;
    
     procedure sort2(var a:mas_slov; n: integer);
     var i,j:integer;
          st:string;
     begin
        for i:=1 to n-1 do
        for j:=i+1 to n do
        if a[i]<a[j] then
        begin st:=a[i]; a[i]:=a[j]; a[j]:=st; end;
     end;

    Запостил: basic, 14 Июня 2010

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

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