Помощь - Поиск - Пользователи - Календарь
Полная версия: Исходник, править
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
Ripper
Задача
Пусть дан текст, заканчивающийся точкой. Текст состоит из слов, разделённых пробелами.
Слово - последовательность латинских букв. Напечатайте слова текста, имеющие
нечетный номер, в которых нет ни одной повторяющейся буквы

Моё решение (скорее набросок):
Код

const n_max=1000; {макс длина текста}
      eot='.';
type litters = set of 'a'..'z'; {тип множества лат букв}
var txt:array [1..n_max] of char; {текст}
    m:litters; s:string; i,n:integer;  f:boolean; c:char;

{процедура ввода текста (по строкам)}
procedure read_text;
var i:integer;
begin
  Writeln ('Введите текст: ');
  i:=0;
    repeat
      repeat
        i:=i+1;
          read(txt[i]);
      until eoln or (i=n_max) or (txt[i]=eot);
      readln;
    until (i=n_max) or (txt[i]=eot);
  if txt[i]=eot then n:=i-1
  else n:=i;
end;

{процедура поиска и печати. чёт не то чую}
procedure find;
var  i:integer;
begin
  i:=1;
  repeat
    s:=''; m:=[]; f:=false;
    repeat
      f:=txt[i] in m;
      m:=m+[txt[i]]; s:=s+txt[i];
    until (txt[i]=' ') or f or (txt[i]='.');
      if not f and odd(i) then write(s);
      i:=i+1
  until txt[i]='.';
  readln;
end;

begin {main}

  read_text;
  find;
  readln;
end.


Вот такие вот дела. Помогите чем сможете...
Артемий
Используй лучше массив строк + Разделение строки на слова + поиск
Ripper
Цитата(Артемий @ 12.05.2007 21:45) *

Используй лучше массив строк
Не думаю, что этот вариант лучше. нам всё-таки каждый символ перебирать придётьтя. может есть другие предложения?
Ripper
Ребята, не получается! Помогите решением
klem4
Массивы тут не нужны

const
limits = [#0..#32,'.',',',':',';','!','?','"'];

procedure CheckWords(s : string);
var
i, j, k, back, n: byte;
flag: Boolean;
begin
i := 1;
n := 0;
while(i<=length(s)) do begin

while(i<=length(s)) and (s[i] in limits) do inc(i);

if i<=length(s) then begin

back := i;

while(i<=length(s)) and not(s[i] in limits) do inc(i);

inc(n);

if odd(n) then begin
flag := true;
k := back;
while (k < i) and (flag) do begin
j := k + 1;
while (j <= i) and (s[k] <> s[j]) do inc(j);
if (j > i) then inc(k) else flag := false;
end;
if flag then writeln(Copy(s, back, i - back))
end;

end;
end;
end;

begin
CheckWords('qewe rty iuw 123 456');
end.
RIPPER
Проблема в том, что мне обязательно нужно использовать множества. Вот и заганяюсь. Может решить можно по-другому?
klem4
А что, в приведенной выше программе использование множеств ты не заметил ?
Гость
Извини смотрю через мобилку. тупанул. огромное спасибо
shutka
Ребята!!Помогите с сортировкой записей по полю строкового типа в алфавитном порядке!!Пожалуйста!!!Ни до кого не могу достучаться!!!!
Lapp
Цитата(shutka @ 14.05.2007 11:58) *

Ребята!!Помогите ...

Shutka, влезать в чужие темы со своими не относящимися к делу вопросами, во-первых, запрещено Правилами, а во-вторых - неприлично. Устное предупреждение
RIPPER
А Всё-таки что не правильно в моём решении? интересно узнать. не сооброжу, что не так.
RIPPER
А Всё-таки что не правильно в моём решении? интересно узнать. не сооброжу, что не так.
RIPPER
Ребята, давайте всё же продолжим дискуссию по теме. Интересно, ч0 процедура поиска не работает.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.