IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Интересный аспект решения задачи о позиционном выводе слов, сделать за один просмотр
volvo
сообщение 5.12.2010 13:05
Сообщение #1


Гость






Условие задачи смотрите здесь: string, разбор по словам


!smoke2.gif

Предложение участникам форума (Показать/Скрыть)



Я очень извиняюсь за вторжение, но я взял на себя смелость выделить этот разговор в отдельную тему. В основном, чтобы не мешать автору решать свои изначальные проблемы. В оригинальной теме также делаю ссылку на эту ветку..
- Lapp
 К началу страницы 
+ Ответить 
 
Closed Topic Открыть новую тему 
Ответов
Unconnected
сообщение 5.12.2010 21:10
Сообщение #2


mea culpa
*****

Группа: Пользователи
Сообщений: 1 372
Пол: Мужской
Реальное имя: Николай

Репутация: -  24  +


Соорудил прогу, по немного другому принципу.. volvo в ЛС не ответил что-то, наверное, она не подходит под критерии, поэтому кладу сюда )

const mc=60;

var words:array[1..mc] of string;
s,sam,buf:string;
i,p,d,bd,j,k:integer;
lets:set of char=['a'..'z']+['A'..'Z'];
begin
writeln('Type in a text');
readln(s);
writeln('Type in a sample');
readln(sam);
p:=0;
d:=0;
bd:=0;
buf:='';
s:=s+' ';
for i:=1 to length(s) do begin
if (s[i] in lets) then buf:=buf+s[i] else begin
d:=pos(sam,buf);
if d>0 then begin
inc(p);
words[p]:=buf;
if d>bd then begin
for j:=1 to p do
for k:=1 to (d-pos(sam,words[j])) do words[j]:=' '+words[j];
bd:=d;
end else begin
for k:=1 to bd-d do words[p]:=' '+words[p];
end;
buf:='';
end;
end;
end;
for i:=1 to p do writeln(words[i]);
readln;
end.




(подразумевается, что слова разделены только пробелами. Писал в делфи, но в паскале тоже должно работать.)

Сообщение отредактировано: Unconnected - 5.12.2010 21:12


--------------------
"Знаешь, стыдно - когда не видно, что услышал всё, что слушал.."
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


Closed Topic Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 9.12.2025 6:09
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"