Работа с текстовым файлом и строками в нем

Общие вопросы программирования, алгоритмы и т.п.

Модератор: Модераторы

Ответить
Sonora
незнакомец
Сообщения: 3
Зарегистрирован: 23.05.2022 20:05:13

Работа с текстовым файлом и строками в нем

Сообщение Sonora »

Помогите пожалуйста. В текстовом файле хранятся строки, состоящие из слов, разделенных одним или несколькими пробелами. Удалить в текущей строке те слова, которые начинаются и заканчиваются на одну и ту же букву, и записать преобразованные строки в новый файл.
Аватара пользователя
Снег Север
долгожитель
Сообщения: 3067
Зарегистрирован: 27.11.2007 15:14:47
Контактная информация:

Сообщение Снег Север »

Стандартная функция фрипаскаля SplitString (модуль strutils)- https://www.freepascal.org/docs-html/rt ... tring.html указать в качестве разделителя пробел и получить набор слов в массиве. Потом пройтись в цикле по этому массиву и сравнивать первый и последний символ каждого строкового элемента. Вуаля!
iskander
энтузиаст
Сообщения: 627
Зарегистрирован: 08.01.2012 18:43:34

Сообщение iskander »

Снег Север писал(а): Потом пройтись в цикле по этому массиву и сравнивать первый и последний символ каждого строкового элемента.
Поколение Z избегает циклов, это прошлый век, они только усложняют логику кода. :)
Аватара пользователя
Снег Север
долгожитель
Сообщения: 3067
Зарегистрирован: 27.11.2007 15:14:47
Контактная информация:

Сообщение Снег Север »

iskander писал(а):Поколение Z избегает циклов,
Поколение "Zа победу" - это я. А то, о чём вы написали - это поколение Ж.
скалогрыз
долгожитель
Сообщения: 1804
Зарегистрирован: 03.09.2008 02:36:48

Сообщение скалогрыз »

Sonora писал(а):В текстовом файле хранятся строки, состоящие из слов, разделенных одним или несколькими пробелами. Удалить в текущей строке те слова, которые начинаются и заканчиваются на одну и ту же букву, и записать преобразованные строки в новый файл.

Код: Выделить всё

function removeWords(inp: string): string;
var
  s: string;
  sb : string;
  ln : longint;
  i,j : longint;
begin
  s := '';
  j := 1;
  for i:=1 to length(inp) do 
  begin
    if inp[i] = ' ' then begin
      sb := Copy(inp, j, i-j);
      ln := length(sb);
      if (sb<>'') and (sb[1]<>sb[ln]) then
       s:=s+sb;
      s:=s+' ';
      j := i+1;
    end;
  end;
  i:=length(inp)+1;
  sb := Copy(inp, j, i-j);
  ln := length(sb);
  if (sb<>'') and (sb[1]<>sb[ln]) then
    s:=s+sb;
  removeWords := s;
end;

var
  f, fout: text;
  s: string;
begin
  assign(f, 'input.txt'); 
  assign(fout, 'output.txt'); 
  reset(f);
  rewrite(fout);
  while not eof(f) do begin
    readln(f, s);
    s := removeWords(s);
    writeln(fout, s);
  end;

  close(f);
  close(fout);
end.
RRYTY
постоялец
Сообщения: 253
Зарегистрирован: 25.12.2021 09:00:32

Сообщение RRYTY »

Снег Север Предложил более развитое решение.
wavebvg
постоялец
Сообщения: 355
Зарегистрирован: 28.02.2008 03:57:35

Сообщение wavebvg »

Ваши решения работают, но, судя по условиям, это классическая задача на машину состояний и решается буфером и посимвольным чтение, иначе бы в условиях не было бы текстового файла.
RRYTY
постоялец
Сообщения: 253
Зарегистрирован: 25.12.2021 09:00:32

Сообщение RRYTY »

Так как объектом анализа/действия является слово (а никак не символ, слово анализируется по критериям первая/последняя - кстати, БУКВА, нифига не символ), то работать нужно со словами, анализируя первую/последнюю буквы.
Аватара пользователя
Снег Север
долгожитель
Сообщения: 3067
Зарегистрирован: 27.11.2007 15:14:47
Контактная информация:

Сообщение Снег Север »

RRYTY, любая буква - это символ. Ваш Кэп.
RRYTY
постоялец
Сообщения: 253
Зарегистрирован: 25.12.2021 09:00:32

Сообщение RRYTY »

любая буква - это символ
Снег Север, не любой символ - буква. По условиям задачи требуется сравнивать не первый/последний символ, а букву. Есть такой грешок, стремление ТЗ воспринимать буквально. :D
Но, на практике, будет работать и при анализе первого/последнего байта, т.е. - символа.
Vadim
долгожитель
Сообщения: 4112
Зарегистрирован: 05.10.2006 08:52:59
Откуда: Красноярск

Сообщение Vadim »

RRYTY писал(а):Но, на практике, будет работать и при анализе первого/последнего байта, т.е. - символа.
Даже с учётом того, что слова на русском языке в кодировке UTF-8/16? ;-)
RRYTY
постоялец
Сообщения: 253
Зарегистрирован: 25.12.2021 09:00:32

Сообщение RRYTY »

Проверил, в локали ru_RU.utf8, нет разных букв с одинаковым последним байтом. Нанайцы пусть проверяют самостоятельно. Вряд ли автор ветки - нанаец. Но, возможно из-за СВО, выполняет некий стратегический нанайский заказ.
Sonora
незнакомец
Сообщения: 3
Зарегистрирован: 23.05.2022 20:05:13

Сообщение Sonora »

Спасибо вам всем большое за помощь!!
Аватара пользователя
zoltanleo
постоялец
Сообщения: 459
Зарегистрирован: 17.10.2013 10:55:01

Сообщение zoltanleo »

Вот почему я иногда читаю срачи - и тут можно выудить полезную для себя инфу. Вроде давно в Паскале, а про SplitString не знал ;)
Ответить