13.05.2011, 18:49 | #1 (permalink) |
Новичок
Регистрация: 13.05.2011
Сообщений: 3
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
Помогите с программой на Delphi
|
13.05.2011, 18:49 | |
Helpmaster
Member
Регистрация: 08.03.2016
Сообщений: 0
|
Я думаю, что похожие темы могут существенно помочь в решении проблемы Помогите с программой Помогите написать программу в Delphi |
14.05.2011, 09:05 | #2 (permalink) |
support
Регистрация: 19.08.2007
Адрес: Зея
Сообщений: 15,797
Записей в дневнике: 71
Сказал(а) спасибо: 166
Поблагодарили 203 раз(а) в 86 сообщениях
Репутация: 75760
|
За слово примем совокупность символов русского и латинского алфавитов, отделенных друг от друга символом пробел или знаком препинания.
Алгоритм решения задачи (примерный, естественно): 1) получаете текст любым оговоренным способом 2) обрабатываете текст посимвольно, выделяя отдельные слова в общий список (можно через процедуру поиска слова или использовать анализ на совпадение полученного слова с элементом списка) 3) используя внутреннее представление символов русского и английского алфавитов, проанализировать каждое слово на символьный состав (воспользуйтесь кодовой таблицей ) и переместить слова в соответствующий список. 4) выдать результирующие списки в оговоренной форме. 3) полученный список
__________________
Убить всех человеков! |
14.05.2011, 13:31 | #5 (permalink) |
Новичок
Регистрация: 13.05.2011
Сообщений: 3
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
да, если не сложно. Может разберусь что к чему
|
Ads | |
Member
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
|
14.05.2011, 17:58 | #6 (permalink) |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
Ну вот - всё, что смог. Работает вроде как надо, но это, увы, Паскаль. Естественно, имена и адреса файлов можно поменять:
Код:
TYPE ChSet=Set of Char; VAR Ch_L,Ch_C,Ch_LC,Ch_S:ChSet; f_in,f_out:TEXT; S,S1:String; Ch:Char; i:Byte; b:Boolean; BEGIN Ch_L:=['A'..'Z']+['a'..'z']; Ch_C:=['А'..'Я']+['а'..'я']; Ch_LC:=['A','B','C','E','H','K','M','O','P','T','X', 'a','c','e','o','p','x','y', 'А','В','Е','К','М','Н','О','Р','С','Т','Х', 'а','е','о','р','с','у','х']; Ch_S:=[' ',',','.','?','!',':',';','"','-',Chr(13)]; Assign(f_in,'D:\txt.txt'); ReSet(f_in); Assign(f_out,'D:\res.txt'); ReWrite(f_out); S1:='******************************'; Repeat Read(f_in,Ch); If not(Ch in Ch_S) then begin i:=1; S1[1]:=Ch; repeat Read(f_in,Ch); Inc(i); If not(Ch in Ch_S) then S1[i]:=Ch; until (Ch in Ch_S) or (EoF(f_in)); If not(Eof(f_in)) then S:=Copy(S1,1,i-1) else S:=Copy(S1,1,i); b:=true; i:=0; repeat Inc(i); if not(S[i] in Ch_LC) then b:=false; until (b=false) or (i=Length(S)); If b then Writeln(f_out,S+' - Latin & Cyrillic') else If S[1] in Ch_L then Writeln(f_out,S+' - Latin') else If S[1] in Ch_C then Writeln(f_out,S+' - Cyrillic'); S1:='******************************'; end; Until EoF(f_in); Close(f_in); Close(f_out); END. |
Ads | |
Member
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
|
|
|