Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.52/48: Рейтинг темы: голосов - 48, средняя оценка - 4.52
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101

Определите значение второго по величине элемента последовательности

27.02.2020, 21:46. Показов 11884. Ответов 166
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
пытаюсь научиться языку Питон-3, просмотрел некоторые поверхностные курсы по языку, вроде все понятно, но когда к примеру стал проходить курс с заданиями вот здесь https://www.coursera.org/learn... -maksimumu то до цикла While дополз, но когда посыпались задания типа: Последовательность состоит из натуральных чисел и завершается числом 0. Определите значение второго по величине элемента в этой последовательности, то есть элемента, который будет наибольшим, если из последовательности удалить одно вхождение наибольшего элемента. плюс всякие числа Фабиочи, то я поплыл...
понятно, что код можно загуглить, НО какой толк от такой учебы...?
вот стою перед выбором, бросать все это программирование т.к. моих мозгов и логики мышления не хватает на это или бросать этот курс, что посоветуете?...
для меня это очень важно...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.02.2020, 21:46
Ответы с готовыми решениями:

Определить значение второго по величине элемента в последовательности
Последовательность состоит из различных натуральных чисел и завершается числом 0. Определите значение второго по величине элемента в этой...

Определить значение второго по величине элемента в данной последовательности
Задача звучит так: Последовательность состоит из различных натуральных чисел и завершается числом 0. Определите значение второго по...

Определите значение второго по величине элемента в последовательности
Написать программу на С++, используя циклы for и/или while, можно использовать if. Последовательность состоит из различных натуральных...

166
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 16:33  [ТС]
Студворк — интернет-сервис помощи студентам
Python
1
2
3
4
a = input()
b, c = (a.find('h')), (a.rfind('h'))
c += 1
print(a[0:b] +a[c::])
вот такой то вариант не удаляет, а только печатает, что мы хотим...
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
18.03.2020, 16:37
Цитата Сообщение от Viktorrus Посмотреть сообщение
Так как count() ищет количество вхождений для одного элемента, то что бы проверить количество вхождений для каждого элемента, очевидно нужно использовать цикл for.
Вот этого не стоит делать. То есть использовать list.count в цикле.
list.count реализована в интерпретаторе очевидным линейным проходом.
C
1
2
3
4
5
6
7
8
9
10
11
12
list_count(PyListObject *self, PyObject *value)
/*[clinic end generated code: output=b1f5d284205ae714 input=3bdc3a5e6f749565]*/
{
    Py_ssize_t count = 0;
    Py_ssize_t i;
 
    for (i = 0; i < Py_SIZE(self); i++) {
        PyObject *obj = self->ob_item[i];
        if (obj == value) {
           count++;
           continue;
        }
А теперь подсчитайте ее сложность на списке из 1000 чисел.
1000 итераций * N линейных проходов count по тому же списку.
0
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 16:46  [ТС]
Цитата Сообщение от DmFat Посмотреть сообщение
print(a[b+1:c])
ну так это не правильно, т.к. надо наоборот удалить все кроме среза...
а этот код просто печатает срез...
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
18.03.2020, 16:50
coa3, ак присвойте строке это срез, в чем проблема то?
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
18.03.2020, 16:55
Цитата Сообщение от coa3 Посмотреть сообщение
вот такой то вариант не удаляет,
В Python строки неизменяемые. Поэтому нельзя просто так взять и удалить срез...
Можно только создать новую строку.
0
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 17:15  [ТС]
получается в задании изначально неправильно условия поставлены об удалении диапазона?
а для чего тогда нужна функция del применяемая в строках?..
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
18.03.2020, 17:19
Цитата Сообщение от coa3 Посмотреть сообщение
del применяемая в строках?
del может удалить строку целиком.
Python
1
2
3
4
5
6
7
8
>>> x = "12345"
>>> del x
>>> x
Traceback (most recent call last):
  File "<pyshell#85>", line 1, in <module>
    x
NameError: name 'x' is not defined
>>>
Цитата Сообщение от coa3 Посмотреть сообщение
в задании изначально неправильно условия поставлены об удалении диапазона?
Вы неверно интерпретировали слова об удалении. Также задача может описывать некий общий подход без учета ЯП, тогда как в конкретных языках он может быть реализован совершенно разными способами.
0
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 18:29  [ТС]
Цитата Сообщение от Garry Galler Посмотреть сообщение
del может удалить строку целиком.
del name
del name[i]
del name[i:j:k] удаление элементов по срезу
del name.attribute
а как же это в справочнике?..
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
18.03.2020, 18:45
Цитата Сообщение от coa3 Посмотреть сообщение
а как же это в справочнике?..
Для списков (и любых изменяемых итерируемых объектов) - пожалуйста. Любой срез, любой элемент.
0
0 / 0 / 0
Регистрация: 15.03.2020
Сообщений: 6
18.03.2020, 18:51
По вашей задаче, делал так:
Python
1
2
3
4
5
6
7
8
s = input()
ln = len(s)
if s.count('h') >= 2:
    a = s.find('h')
    b = s.rfind('h')
    print(s[:a] + s[b+1:])
else:
    print()
Ничего не удалял, просто вывел на печать.
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
18.03.2020, 20:57
Цитата Сообщение от coa3 Посмотреть сообщение
Дана строка, в которой буква h встречается минимум два раза.
Поэтому для начала нужно правильно написать пример, который будет универсальным.
Python
1
a = 'ghghhgvhghkk'
Дальше используем методы find() и rfind()
Синтаксис методов find() и rfind():
Python
1
2
3
4
5
6
7
8
9
str.find(sub[, start[, end]]) -> int
 
sub - Подстрока, начальный индекс размещения которой требуется определить.
 
start=0 - Индекс начала среза в исходной строке, в котором требуется отыскать подстроку.
 
end=None - Индекс конца среза в исходной строке, в котором требуется отыскать подстроку.
 
Если подстрока не найдена, возвращает -1.
и
Python
1
2
str.rfind(sub[, start[, end]]) -> int
Возвращает самый высокий индекс в строке, где находится подстрока sub, такой, что sub содержится в s[start: end]. Необязательные аргументы start и end интерпретируются как в нотации среза. Возвращают -1 в случае неудачи.
DmFat, не так понял условие задачи и выводит срез между первой и последней буквами а по условию
Цитата Сообщение от coa3 Посмотреть сообщение
Удалите из этой строки первое и
# последнее вхождение буквы h,а также все символы, находящиеся между ними.
coa3, У тебя правильная идея, но вот только del не может удалить срез в строке, так как строка, в отличие от списка, является неизменяемым объектом. Поэтому мы можем только создать новую строку, удовлетворяющую заданному условию.
Вот правильное решение:
Python
1
2
3
4
5
a = 'ghghhgvhghkk'
b = a.find('h')
c = a.rfind('h')
res = a[:b] + a[c+1:]
print(res)
Выводит:
Python
1
gkk
где g стоит перед первой h, а kk после последней h.

Добавлено через 9 минут
coa3, Я медлительный, и пока писал свой комментарий, тебе уже объяснили, что строка неизменяемый объект.

Добавлено через 7 минут
Цитата Сообщение от Garry Galler Посмотреть сообщение
Вот этого не стоит делать. То есть использовать list.count в цикле.
Я предложил такой не оптимальный вариант только для практики как решить проблему, пока он не знает других методов. И потренировать работу с циклом
0
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 21:00  [ТС]
Цитата Сообщение от le6681 Посмотреть сообщение
По вашей задаче, делал так:
ну по мне так сложновато и многовато

Python
1
2
3
a = input()
b, c = (a.find('h')), (a.rfind('h'))
print(a[0:b] + a[c +1::])
так то за три строки уложился, интересно про del понять..
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
18.03.2020, 21:07
coa3, У тебя правильно, за исключением лишнего указания начала и конца среза, которые и так берутся по умолчанию. Правильнее так
Python
1
print(a[:b] + a[c +1:])
И : должно идти два раза, только если мы указываем шаг отличный от 1 и отсуствует конечное значение среза. Например
Python
1
print(a[0:b] + a[c +1::2])
1
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 21:12  [ТС]
Цитата Сообщение от Viktorrus Посмотреть сообщение
У тебя правильная идея, но вот только del не может удалить срез в строке, так как строка, в отличие от списка, является неизменяемым объектом.
получается если строку преобразовать в список, то можно было спокойно удалить, то что хотел?
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
18.03.2020, 21:18
Цитата Сообщение от coa3 Посмотреть сообщение
интересно про del понять..
Нужно просто понять, что строка не изменяема. Как мы создали строку, так с ней и работаем в ее первоначальном виде, изменить ее никак нельзя, только удалить ее. А так же, взяв за основу эту строку, создать на ее основе другую, новую строку. Причем первая останется не измененной.
0
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 21:19  [ТС]
Цитата Сообщение от Viktorrus Посмотреть сообщение
У тебя правильная идея, но вот только del не может удалить срез в строке, так как строка, в отличие от списка, является неизменяемым объектом.
получается если строку преобразовать в список, то можно было бы воспользоваться del name[i:j]..?
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
18.03.2020, 21:22
Цитата Сообщение от coa3 Посмотреть сообщение
получается если строку преобразовать в список, то можно было спокойно удалить, то что хотел?
Да так можно, преобразовать в список символов, произвести изменения, а затем вновь преобразовать в строку. Но это будет новая, другая строка, а первая останется неизменной, так как она не изменяема.

Добавлено через 1 минуту
Но этот вариант решения хуже, чем просто создание новой строки используя срезы, которые не включают ту часть, которую нужно удалить.
1
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
18.03.2020, 22:29  [ТС]
Цитата Сообщение от Viktorrus Посмотреть сообщение
str.find(sub[, start[, end]]) -> int
вот не совсем разобрался с этим...

вот на примере если:

Python
1
2
3
4
5
6
7
s = 'cofgfee'
pos = s.find('f')
print(pos)
if pos == -1:
    print(-2)
else:
    print(s.find('f', pos + 1))
как работает последняя строка?
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
19.03.2020, 05:05
Python
1
2
3
4
5
6
7
8
9
s = 'cofgfee'
pos = s.find('f')
print(pos)
if pos == -1:         # метод find() возвращает -1 только в том случае, 
                      # если не находит в строке нужную подстроку. 
                      # У тебя в примере -1 вернуть не может, так как 'f' в строке есть. 
    print(-2)      # эта строка кода не нужна
else:
    print(s.find('f', pos + 1)) # эта запись  ищет вторую букву f в строке и возвращает ее позицию, и печатает.
Потому, что она поиск начинает с позиции следующей за позицией первой буквы f (pos+1).

Добавлено через 17 минут
coa3, У тебя здесь не доделанный пример, который при наличии цикла while мог бы искать позиции всех букв f входящих в строку.
Кстати для практики, ты мог бы попробовать решить такую задачу.
Задача: Найти позиции всех букв 'f', которые есть в заданной строке.
И для примера использовать строку 'cofgfee' .
1
1 / 1 / 0
Регистрация: 27.02.2020
Сообщений: 101
19.03.2020, 14:27  [ТС]
Цитата Сообщение от Viktorrus Посмотреть сообщение
Задача: Найти позиции всех букв 'f', которые есть в заданной строке.
И для примера использовать строку 'cofgfee' .
так здесь легко, т.к. 9 строка это готовый ключ к циклу...))
Python
1
2
3
4
5
6
7
8
s = 'cofgfee'
pos = s.find('f')
i = 0
while pos != -1:
    pos = s.find('f', pos+ i)
    i += 1
    if pos != -1: 
        print(pos)
Добавлено через 25 минут
Python
1
2
3
4
#Дана строка, состоящая ровно из двух слов, разделенных пробелом. Переставьте эти слова местами. Результат запишите в
# строку и выведите получившуюся строку. При решении этой задачи нельзя пользоваться циклами и инструкцией if.
n = input().split()
print(n[-1] + n[0], sep=' ', end=' ')
bb mm
mmbb
как правильно сделать пробел между символами в данном случае?..

Добавлено через 40 минут
Python
1
2
n = 'aa bb'.split()
print(n[-1] + ' ' + n[0])
разобрался..
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.03.2020, 14:27
Помогаю со студенческими работами здесь

Определите значение второго по величине элемента в последовательности
Последовательность состоит из различных натуральных чисел и завершается числом 0. Определите значение второго по величине элемента в этой...

Определите значение второго по величине элемента в последовательности
Последовательность состоит из натуральных чисел и завершается числом 0. Определите значение второго по величине элемента в этой...

Определите значение второго по величине элемента в этой последовательности
Последовательность состоит из натуральных чисел и завершается числом 0. Определите значение второго по величине элемента в этой...

(использовать рекурсию) Определите значение второго по величине элемента в этой последовательности
3. (использовать рекурсию) Дана последовательность натуральных чисел (одно число в строке), завершающаяся числом 0. Определите значение...

Определите значение второго по величине элемента последовательности рекурсией без циклов
Дана последовательность натуральных чисел (одно число в строке), завершающаяся числом 0. Определите значение второго по величине ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
120
Закрытая тема Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru