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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Python] Подсчет слов в строке 
V
    Опции темы
Paranorma
Дата 29.1.2007, 19:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Программка подсчитывает количество слов, разделенных произвольным количеством пробелов, во введенных строках.  Split и for использовать нельзя.
В очередной раз создается все с помощью while. Вероятно, используется и вложенный while (Я сама просто еще никак не могу понять)...

Я начала так:


Код

a = []
while True:
    s = raw_input(">>>")
    if not s:
        break
    a.append(s)
i = 0
while i < len(a):
    s = a[i]
    probel = " "
    while 



Например, я ввожу строку "house near the lake" или "   house      near         the     lake" (кол-во пробелов любое).
В окне калькулятора соответственно должно появится число 4(в строке же 4 слова введено).
PM MAIL Skype Jabber MSN   Вверх
Night_xxx
Дата 29.1.2007, 22:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 87
Регистрация: 7.1.2007
Где: Набережные Челны

Репутация: 0
Всего: 0



Не знаю как в Pythone но в паскале алгоритм посчета слов вот какой 

simvol=' ';
    
    int count = 0; 

    for(int i = 0; i<(int)strlen(str) && str[i]!=0; i ++) 
    {
    if(str[i] == simvol) count++;
                }
cout<<count+1;

Может поможет тебе понять как работает.

Добавлено @ 22:54 
ой не в паскале а в С++
PM MAIL   Вверх
Strannik
Дата 29.1.2007, 23:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Алгоритм на словах (ибо питона не знаю):
Идём по строке начиная со 2 символа и смотрим: если предыдущий символ не пробел и текущий символ пробел, то увеличить кол-во слов на 1. Если последний символ строки не пробел, то увеличить кол-во слов ещё на 1.
PM MAIL   Вверх
doomik
Дата 29.1.2007, 23:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Одинокий волк
**


Профиль
Группа: Участник
Сообщений: 360
Регистрация: 25.10.2005
Где: #vingrad

Репутация: 3
Всего: 15



Код

# Программа получает от пользователя строку а дальше добавляет каждый символ из строки в массив
# дальше идёт проверка если  массив наченается без пробела то Word получает 1
# через цикл while проверяем если в массиве элемент s[i] равен пробелу и элемент s[i+1] не равен пробелу 
# если True то добавляем к Word  + 1  

s = []
i = Word = 0

String = raw_input("Enter string:")

while i < len(String): # Добавляем каждый элемент из строки
    s.append(String[i])
    i += 1
    
i = 0
if ( s[0] != ' ' ): # Проверка если массив начинается со слова
       Word = 1
       
while i < len(String)-1: # Считаем слова
    if ( s[i] == ' ') and ( s[i+1] != ' '):
        Word += 1
    i += 1
    
print Word



--------------------
"Единственный способ изучать новый язык программирования - писать на нем 
программы." 
- Brian Kernighan

Remember, st1ng3r 
/server irc.ircline.ru /j #vingrad
PM   Вверх
Paranorma
Дата 29.1.2007, 23:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



 smile  smile  smile 


Я вот такую штучку накатала.

Код

a = []
while True:
    s = raw_input(">>>")
    if not s:
        break
    a.append(s)
stroka = 0
for s in a:
    for probel in s:
        if probel != " ":
            stroka = stroka + 1
print stroka


Но эта прога считает все буквы кроме пробела, а мне надо, чтоб не по буквам считала, а по словам. Кроме того нельзя было использовать for   smile 
PM MAIL Skype Jabber MSN   Вверх
V.A.KeRneL
Дата 29.1.2007, 23:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Night_xxx, очевидно, не понял задание и поэтому написал подсёт пробелов в строке + 1 на сях... smile

А вот Strannik привёл действенный алгоритм. 
Вот его реализация: 
Код

list = []

while True: 
    str = raw_input(">>>")
    if (not str): 
        break
    list.append(str)

slov = 0
i = 0
while (i < len(list)): 
    str = list[i]
    j = 1
    while (j < len(str)): 
        if ((str[j - 1] != ' ') and (str[j] == ' ')): 
            slov += 1
        j += 1
    if (str[-1] != ' '): 
        slov += 1
    i += 1

print slov


Упс, долго писал, опередили. smile 
... Хотя, нет, у меня лучше. smile 


Это сообщение отредактировал(а) V.A.KeRneL - 3.2.2007, 21:39


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Paranorma
Дата 29.1.2007, 23:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



doomik, огромное спасибо! Но воот эта часть 


Код

a = []
while True:
    s = raw_input(">>>")
    if not s:
        break
    a.append(s)
 должна быть обязательно, просто я в твоем варианте вижу, что после Enter каждая строка сразу печатается, а у меня ввод строк прекращается введением пустой строки. 
PM MAIL Skype Jabber MSN   Вверх
Strannik
Дата 30.1.2007, 00:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Цитата

Night_xxx, очевидно, не понял задание и поэтому написал подсчёт пробелов в строке + 1 на сях... 

Он написал абсолютно правильный алгоритм, но с условием что слова разделены только одним пробелом.

Это сообщение отредактировал(а) Strannik - 30.1.2007, 18:56
PM MAIL   Вверх
Paranorma
Дата 30.1.2007, 00:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Ребята! Всем огромное спасибо, что меня не бросаете! smile 
PM MAIL Skype Jabber MSN   Вверх
V.A.KeRneL
  Дата 30.1.2007, 00:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Цитата(Strannik @  30.1.2007, 00:01 Найти цитируемый пост)

Он написал абсолютно правильный алгоритм, но с условием что слова разделены только одним пробелом.

smile Ха, действительно! И ещё надо, чтобы текст пробелами не окаймлялся в начале и конце.
Но, задание-то было чётко сформулировано, и оно гласит, что пробелов сколько угодно и где угодно! smile

З.Ы. И ещё, строчек может быть больше одной. Именно этим моё решение лучше doomik'овского.

З.З.Ы. Paranorma, свои темы, всё-таки, не забывай своевременно помечать решёнными!


Это сообщение отредактировал(а) V.A.KeRneL - 30.1.2007, 00:33


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Strannik
Дата 30.1.2007, 00:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Цитата

 Ха, действительно! И ещё надо, чтобы текст пробелами не окаймлялся в начале и конце.
Но, задание-то было чётко сформулировано, и оно гласит, что пробелов сколько угодно и где угодно! 

З.Ы. И ещё строчек может быть больше одной. Именно этим моё решение лучше doomik'овского
.
Да согласен, согласен... просто есть у меня привычка такая... людей защищать и к объективности стремиться где надо и где не надо..

Это сообщение отредактировал(а) Strannik - 30.1.2007, 18:55
PM MAIL   Вверх
Paranorma
Дата 30.1.2007, 00:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Я эту программку на свой лад (точнее, как препод любит) переделала

Код

a = []
while True: 
    s = raw_input(">>>")
    if not s: 
        break
    a.append(s)
word = 0
i = 0
while i < len (a): 
    s = a[i]
    j = 0
    while j < len(s): 
        if s[0] != " " and s[j] == " ": 
            word = word + 1
        j = j + 1
    if s[-1] != " ": 
        word = word + 1
    i = i + 1
print word


Как я вижу, эта программка нормально работает, только если введен один пробел между словами. если допустить что сначала я ввожу 6 пробелов, потом слово, потом 3 пробела и еще слово. Фишка в том, что слова должны подсчитываться независимо от количества пробелов между словами.

Добавлено @ 00:44 
Пардон! Я кажется сама с переделкой нагрешила, исправлюсь.
PM MAIL Skype Jabber MSN   Вверх
V.A.KeRneL
Дата 30.1.2007, 09:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Paranorma, в 13-ой строчке ``0'' на ``j - 1'' исправила, да? 
Ну так приведи лучше исправленый код, чем этот с ачипяткой.



--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Paranorma
Дата 30.1.2007, 18:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



 smile  Блин... Ребята, выручайте, плиз!
Вот если надо написать прогу считающую слова но строки всегда начинаются именно со слова и заканчиваются словом. то есть тут строгое условие что никаких пробелов в начале и в конце, а все слова разделены только одним пробелом... Думала долго... изобразила этот бред, но не работает...


Код

a = []
while True: 
    s = raw_input(">>>")
    if not s: 
        break
    a.append(s)
i = 0
stroka = 0
while i < len(a):
    s = a[i]
    j = 0
    while j < len(s):
        if s[j] != " ":
            stroka = stroka + 1
    j = j + 1
i = i + 1
print stroka

PM MAIL Skype Jabber MSN   Вверх
V.A.KeRneL
  Дата 30.1.2007, 18:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Paranorma, дык эта задача — частный слуай предыдущей. Зачем изобретать одноколёсный велосипед? smile smile
Препод что ли требует?



--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Paranorma
Дата 30.1.2007, 18:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Ну а кто же? конечно, он.
PM MAIL Skype Jabber MSN   Вверх
V.A.KeRneL
  Дата 30.1.2007, 18:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Ну, ладно, если надо, то пожалуйста: 
Код

a = []

while True: 
    s = raw_input(">>>")
    if (not s): 
        break
    a.append(s)

i = 0
slov = 0
while (i < len(a)):
    s = a[i]
    j = 0
    while (j < len(s)):
        if (s[j] == ' '):  # Здесь надо именно «==»
            slov += 1
        j += 1  # <<< Отступы...
    i += 1      # <<< ...нужны в Python'е! ;-)
if (len(s) > 0):  # Если строка не пустая...
    slov += 1     # ..., то в ней кол-во слов == кол-ву пробелов + 1

print slov

Думать-то, слава богу, тут не надо совсем. smile


Это сообщение отредактировал(а) V.A.KeRneL - 3.2.2007, 21:46


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Strannik
Дата 30.1.2007, 19:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Но если сильно надо то вроде так: 
  строки 11-14 меняем на

Код

    j = 1
    while j < len(s):
        if s[j] == " ":
            stroka = stroka + 1
    j = j + 1


Я в питоне не силён, так что если что не так - извините.
PM MAIL   Вверх
Paranorma
Дата 30.1.2007, 19:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Спасибо тебе огромное! А то у меня 1 курс, вообще ничего не понимаю почти. smile  smile 
PM MAIL Skype Jabber MSN   Вверх
Strannik
Дата 30.1.2007, 19:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Цитата

Спасибо тебе огромное! А то у меня 1 курс, вообще ничего не понимаю почти. 

Тебе тоже! Ещё 10-20 вопросов и я Питон выучу!
А вообще - главная сила это алгоритмы, если знаешь алгоритм то его можно реализовать на любом языке, даже на том которого почти не знаешь.
PM MAIL   Вверх
V.A.KeRneL
  Дата 30.1.2007, 21:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Цитата(Paranorma @  30.1.2007, 19:16 Найти цитируемый пост)

Спасибо тебе огромное!

«Тебе» или «вам»? smile

Цитата(Strannik @  30.1.2007, 19:21 Найти цитируемый пост)

Ещё 10-20 вопросов и я Питон выучу!
А вообще — главная сила это алгоритмы, если знаешь алгоритм, то его можно реализовать на любом языке, даже на том которого почти не знаешь.

Это про меня! smile


Это сообщение отредактировал(а) V.A.KeRneL - 30.1.2007, 21:04


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Strannik
Дата 30.1.2007, 23:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Цитата

«Тебе» или «вам»? 


В мозгу вопрошающих мы  предстаём в виде одного многоликого и "всезнающего" программера.

ой... что-то меня сегодня на оффтоп тянет, не к добру это...
PM MAIL   Вверх
V.A.KeRneL
  Дата 31.1.2007, 11:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



smile


Это сообщение отредактировал(а) V.A.KeRneL - 4.2.2007, 11:12


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Paranorma
Дата 1.2.2007, 13:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Ребята, чего к словам цепляться? Конечно, всем спасибо! smile 
PM MAIL Skype Jabber MSN   Вверх
Alexeis
Дата 1.2.2007, 16:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Амеба
Group Icon


Профиль
Группа: Админ
Сообщений: 11743
Регистрация: 12.10.2005
Где: Зеленоград

Репутация: 23
Всего: 459



Модератор: прекращаем оффтоп. На 2 полезных сообщения 8 флейма. Есть же спец раздел. Флейм


--------------------
Vit вечная память.

Обсуждение действий администрации форума производятся только в этом форуме

гениальность идеи состоит в том, что ее невозможно придумать
PM ICQ Skype   Вверх
Limpopo
Дата 1.2.2007, 23:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 17
Регистрация: 20.9.2006

Репутация: 0
Всего: 1



попробуй так

Код

begin
readln(st);
st:=' '+st+' ';
i:=1;
repeat
 K:=0;
 if (st[i] in razd) and not (st[i+1] in razd) then
 begin
stn:=st[i+1];
stpoz:=i+1;
repeat
 inc(k);
 inc(i);
until not (st[i] in razd) and (st[i+1] in razd);
............
end ;
end;
.............
end.



Вот так можно выделять слово часть моей лабы
если требует без пробелов то просто не прибавляй 
и измени условие включения в множество


PM MAIL   Вверх
Alexeis
Дата 2.2.2007, 02:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Амеба
Group Icon


Профиль
Группа: Админ
Сообщений: 11743
Регистрация: 12.10.2005
Где: Зеленоград

Репутация: 23
Всего: 459



Limpopo, внимательно читайте заголовок. Язык программирования Python, а не делфи  smile 


--------------------
Vit вечная память.

Обсуждение действий администрации форума производятся только в этом форуме

гениальность идеи состоит в том, что ее невозможно придумать
PM ICQ Skype   Вверх
Paranorma
Дата 2.2.2007, 20:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Ребята! Хотя бы поподробнее мне объясните, пожалуйста!
Препод на счет задания еще вот какие рекомендации дал:

- слова могут буть разделены любым количеством
  пробелов;
- пробелы могут быть в начале и конце строки;
- строка может состоять из одних пробелов;

Подсказка:
- надо завести перменную whiteSpace которая принимает
  начения False/True в зависимости о того является
  ли s[j] пробелом;
- whiteSpace писваивается значение True перед обработкой
  очередной строки;
- whiteSpace меняет свое значение с True на False в тот
  момент когда вы наталкиваитесь на начало слова.
  Именно в этот момент надо увеличивать счетчик слов



Я накарябала вот что:


Код

a = []
while True: 
    s = raw_input(">>>")
    if not s: 
        break
    a.append(s)
count = 0
i = 0
while i < len(a):
    s = a[i]
    j = 0
    while j < len(s):
        if whitespace = True:
            s[j] == " "
        if whitespace = False:
            s[j] != " "
        count = count + 1
        j= j + 1
i = i + 1            
print count


У меня все это не работает smile в чем трабла? как быть?
PM MAIL Skype Jabber MSN   Вверх
Strannik
Дата 2.2.2007, 22:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Чтот мне логика твоего препода не понятна....

Ну а вообще, кроме логики, в питоне условный оператор выглядит так:

Код

 if условие:
    то что надо делать если
    условие истино 


А у тебя наоборот. Но и с логикой в проге что-то не то. Сейчас подумаю ещё...

Добавлено @ 22:27 
Цитата

- слова могут буть разделены любым количеством
  пробелов;
- пробелы могут быть в начале и конце строки;
- строка может состоять из одних пробелов;


Агрх!! Я твоего прэпода рэзат буду!!!! Проги, которые мы постили - они для таких условий работают! И работают красиво, а не через ****, как хочет твой препод.

Добавлено @ 22:32 
Цитата

- надо завести перменную whiteSpace которая принимает
  начения False/True в зависимости о того является
  ли s[j] пробелом;
- whiteSpace писваивается значение True перед обработкой
  очередной строки;
- whiteSpace меняет свое значение с True на False в тот
  момент когда вы наталкиваитесь на начало слова.
  Именно в этот момент надо увеличивать счетчик слов

Терпеть не могу огда препод дает задание и тычет под нос как это делать.

Логика нормальной программы такова:
 Необходимо подсчитать кол-во ситуаций *начало слова*.
 Условие возникновения такой ситуации: s[i-1]=" " и s[i]!=" ".

Всё, не надо никаких булевских переменных и т.д.

Добавлено @ 22:37 
Вот, шмат программы V.A. KeRnel который реализует эту схему (я этот код чтуь-чуть переделал):

Код

    j=2; 
    while j <= len(s): 
        if s[j] != " " and s[j-1] == " ": 
            word = word + 1
        j = j + 1


Это сообщение отредактировал(а) Strannik - 2.2.2007, 22:28
PM MAIL   Вверх
V.A.KeRneL
  Дата 3.2.2007, 18:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Цитата(Strannik @  2.2.2007, 22:25 Найти цитируемый пост)

Код

    j=2; 
    while j <= len(s): 
        if s[j] != " " and s[j-1] == " ": 
            word = word + 1
        j = j + 1


Strannik, только индексация массивов (списков в питоновской терминологии) идёт не с 1 (как в Паскале), а с 0 (как в Си), поэтому непонятно к ему это измениение. smile (Подозреваю, что в первую очередь для измениения имён переменных под свой вкус.)
Если пофиксить это (
Код

    j = 1
    while j < len(s): 
        if s[j - 1] == ' ' and s[j] != ' ': 
            word = word + 1
        j = j + 1

), то, всё равно, придётся ещё заменить 
Код

    if (s[-1] != ' '): 
        word += 1

 на 
Код

    if (s[0] != ' '): 
        word += 1


А так, конечно, моя программа (1-ая) работает абсолютно корректно во всех случаях. (Если твоему преподу кажется, что не так, пусть приведёт контрпример.) (2-ая — для второго условия (упрощённого).)

З.Ы. Paranorma, если тебе самой непонятно моё решение, то я могу продолжить писать подробные комментарии, но ты почему-то толи не замечаешь их, толи пугаешься увеличевшегося за их счёт кода... smile


Это сообщение отредактировал(а) V.A.KeRneL - 3.2.2007, 21:33


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Strannik
Дата 3.2.2007, 19:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.1.2007

Репутация: 1
Всего: 2



Цитата

только индексация массивов (списков в питоновской терминологии) идёт не с 1 (как в Паскале), а с 0 (как в Си)

Виноват, исправлюсь. А что и зачем я менял - уже не помню... вечер был, спать хотелось.
PM MAIL   Вверх
V.A.KeRneL
Дата 3.2.2007, 21:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Но если уж, преподу Paranorma'ы будет приятно через ***** (булевские переменные smile), то пожалуйста: 
Код

# -*- coding: windows-1251 -*-

list = []

while True: 
    str = raw_input(">>>")
    if (not str): 
        break
    list.append(str)

slov = 0
i = 0
is_white_space = False
while (i < len(list)): 
    str = list[i]
    is_white_space = True
    j = 0
    while (j < len(str)): 
        if ((str[j] != ' ') and is_white_space): 
            is_white_space = False
            slov += 1
            #print [i, j]  # использовалось для отладки (отображает 
                           # текущие номер строки и символа в ней)
        if (str[j] == ' '): 
            is_white_space = True
        j += 1
    i += 1

print slov



Это сообщение отредактировал(а) V.A.KeRneL - 3.2.2007, 21:31


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Paranorma
Дата 4.2.2007, 00:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 102
Регистрация: 1.1.2007

Репутация: 1
Всего: 1



Препод вот это просил, оказывается:

Код

a = []
while True: 
    s = raw_input(">>>")
    if not s: 
        break
    a.append(s)
    
count = 0
i = 0
while i < len(a):
    s = a[i]
    whitespace = True
    j = 0
    while j < len(s):
         if s[j] == " ":
            whitespace = True
         if s[j] != " ":
             if whitespace:
                 count += 1
             whitespace = False
         j = j + 1
    i = i + 1            
print count

PM MAIL Skype Jabber MSN   Вверх
V.A.KeRneL
  Дата 4.2.2007, 11:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vadim A. Kazantsev
**


Профиль
Группа: Участник
Сообщений: 291
Регистрация: 3.12.2006
Где: Moscow, Russia

Репутация: 7
Всего: 14



Paranorma3-тье моё решение аналогично. smile

З.Ы. Нда, странный у вас препод. Он что, хочет, чтоб вы всё слово в слово писали, как он хочет? Т.е. учит вас не на программистов, а на Вольфов Мессингов?!. smile


Это сообщение отредактировал(а) V.A.KeRneL - 4.2.2007, 16:55


--------------------
«C'est un pense-creux d'ici. C'est le meilleur et le plus irascible homme du monde...» © Ф.М. Достоевский, «Бесы»
---/)/)---(\.../)---(\(\
--(':'=)---(=';'=)---(=':')
(")(")..)-(").--.(")-(..(")(")

PM MAIL IM ICQ AOL YIM MSN   Вверх
Страницы: (3) [Все] 1 2 3 
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.1525 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.