Antichat снова доступен.
Форум Antichat (Античат) возвращается и снова открыт для пользователей.
Здесь обсуждаются безопасность, программирование, технологии и многое другое.
Сообщество снова собирается вместе.
Новый адрес: forum.antichat.xyz
 |

28.12.2008, 16:22
|
|
Banned
Регистрация: 04.06.2008
Сообщений: 402
Провел на форуме: 2267346
Репутация:
719
|
|
задача Pascal
Задание
Разделитель — один из символов « ,.;:!?"'» (начиная с пробела и заканчивая апострофом). Буква — любой символ, отличный от разделителя. Слово — последовательность букв, ограниченная с каждой стороны разделителем или концом строки. Например, в строке «x9i23!слово, ,» два слова — «x9i23» и «слово».
Исходная строка вводится с клавиатуры, изменённая строка выводится на экран. Если в задании используется «заданное» слово, оно также вводится с клавиатуры. Разделители в программе представляются как множество.
Требуется произвести одно из следующих действий (при всех манипуляциях со словами разделители сохранять без изменений):
удалить слова, содержащие хотя бы 4 различные буквы, и продублировать остальные слова;
Есть 2 сорца: один - другой вариант, второй - этот , но не верно выполняющийся.
Кто напишет и за скока ?
Срок - Сегодня до 00.00 (мск)
|
|
|

28.12.2008, 17:07
|
|
Новичок
Регистрация: 20.12.2008
Сообщений: 24
Провел на форуме: 1187799
Репутация:
62
|
|
var delim,sent,result,tmps:string;
dArr : array[1..100] of byte;
i,p,k,w:byte;
begin
delim := ' ,.;:!?"''';
sent:= 'Let''s say, there is a test, simple: example. Clear? Sure! Next; aga well.';
sent:= ' '+sent+' ';
w:=0;
for i:=1 to 100 do dArr[i]:=0;
for i:=1 to length(delim) do
begin
tmps:=sent;
k:=pos(delim[i],tmps); p:=0;
while (k>0) do
begin
p:=p+k;
w:=w+1;
dArr[w]:=p;
Delete(tmps,1,k);
k:=pos(delim[i],tmps);
end;
end;
for i:=1 to w-1 do
for k:=i+1 to w do
if (dArr[i]>dArr[k]) then
begin
p:=dArr[i];
dArr[i]:=dArr[k];
dArr[k]:=p;
end;
result:='';
for i:=1 to w-1 do
if (dArr[i+1]-dArr[i]>1) then
begin
tmps := copy(sent,1+dArr[i],dArr[i+1]-1-dArr[i]);
if (tmps[1]=tmps[length(tmps)]) then
result:=result+sent[dArr[i+1]]
else
result:=result+tmps+' '+tmps+sent[dArr[i+1]]
end
else
result:=result+sent[dArr[i+1]];
writeln(' Original: '+sent);
writeln(' Result: '+result);
end.
Отпишись потом...
|
|
|

28.12.2008, 17:20
|
|
Banned
Регистрация: 04.06.2008
Сообщений: 402
Провел на форуме: 2267346
Репутация:
719
|
|
Работает. Спс. Стучи в аську, могу номерок подарить или заплатить
|
|
|
|
 |
Похожие темы
|
| Тема |
Автор |
Раздел |
Ответов |
Последнее сообщение |
|
СРОЧНО!!! Turbo Pascal
|
MAG0t |
Разное - Покупка, продажа, обмен |
3 |
23.12.2008 18:36 |
|
TURBO PASCAL 7 1.0
|
Daemond |
С/С++, C#, Delphi, .NET, Asm |
1 |
03.12.2008 22:32 |
|
Задача на Ассемблере
|
NEt_hunter |
С/С++, C#, Delphi, .NET, Asm |
1 |
27.10.2006 22:15 |
|
Pascal. Задачи.
|
Zakary |
Болталка |
17 |
18.05.2006 09:59 |
|
Стоит следующая задача. Отлавливаем снифер.
|
Егорыч+++ |
PHP, PERL, MySQL, JavaScript |
21 |
27.07.2005 16:18 |
|
Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
|
|
|
|