Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/190: Рейтинг темы: голосов - 190, средняя оценка - 4.67
6 / 5 / 4
Регистрация: 14.01.2017
Сообщений: 294

Необходимо определить, является ли последовательность цифр при просмотре справа налево упорядоченной по возрастанию

22.09.2018, 22:25. Показов 41285. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано натуральное число n. Необходимо определить, является ли последовательность его цифр при просмотре справа налево упорядоченной по возрастанию.

Прога не проходит тест, когда все цифры равны. Например 111111. Должна выводить NO, а выводит YES
(кстати, где разметка питона в списке на форуме?)

Python
1
2
3
4
5
6
7
8
a = int(input())
b = "YES"
while a>9:
  #print(a,b)
  if (a%10)>=(a/10%10):
    b = "NO"
  a = a//10
print(b)
Добавлено через 6 минут
я нашел разметку питона, но было слишком поздно(((
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.09.2018, 22:25
Ответы с готовыми решениями:

Определить, является ли последовательность цифр числа при просмотре справа налево упорядоченной по возрастанию
Дано натуральное число n. Необходимо определить, является ли последовательность его цифр при просмотре справа налево упорядоченной по...

Является ли последовательность цифр числа при просмотре их справа налево упорядоченной по возрастанию
Используя цикл с постусловием repeat решить задачу: Дано натуральное число. Установить, является ли последовательность его цифр при...

Является ли последовательность цифр числа при просмотре их справа налево упорядоченной по неубыванию
int a; bool flag; a = int.Parse(Console.ReadLine()); flag = true; while (a > 9) { ...

7
3 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 188
22.09.2018, 23:19
Python
1
2
3
4
5
6
7
8
9
10
a = input()
 
for i in range(len(a)):
    if a[i]>a[i-1]:
        i += 1
        b = "Yes"
    else:
        b = "No"
        
print(b)
Добавлено через 6 минут
Поправил - справа налево

Python
1
2
3
4
5
6
7
8
9
10
a = input()
 
for i in range(len(a)):
    if a[i]<a[i-1]:
        i += 1
        b = "Yes"
    else:
        b = "No"
        
print(b)
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
22.09.2018, 23:23
Цитата Сообщение от Глеб Иванов Посмотреть сообщение
i += 1
Зачем?
0
3 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 188
22.09.2018, 23:34
Действительно) Спасибо за поправку, намудрил

Но мне кажется тест все равно не примет мой вариант, нужно считать интом, а я считал как строку.
0
 Аватар для Semen-Semenich
5233 / 3478 / 1175
Регистрация: 21.03.2016
Сообщений: 8,305
23.09.2018, 16:57
Цитата Сообщение от Глеб Иванов Посмотреть сообщение
Но мне кажется тест все равно не примет мой вариант
тест читает из файла а там всегда строки так что должен пройти, вообще любой ввод это строка если вы явно не указываете int
Python
1
2
3
4
5
6
7
8
9
10
number = int(input())
answer = "YES"
while number//10:
    sample_right = number%10
    number = number //10
    sample_left = number%10
    if sample_right >= sample_left:
        answer = "NO"
        break
print(answer)
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
23.09.2018, 19:48
Цитата Сообщение от Глеб Иванов Посмотреть сообщение
нужно считать интом
Тут дело даже не в этом - лексикографический порядок сравнения все равно сработает.
Недочет в вашем коде в том, что 0 элемент сравнивается с -1 (последним). Да, если выводить Yes\\No как у вас после каждой итерации - все работает.
Но по логике нужно прекращать цикл сразу после первого 'No' \False (как у Semen-Semenich'а, ), а не гонять весь цикл: это лишние операции - если где-то False, значит общий результат тоже False - возрастание нарушено.
И в этом случае сравнение a[0] и a[-1] будет ошибочным.

Вот еще варианты:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
for a in ['9876543210','9876543211','1876543210']:
    # пробежка с конца
    for i in range(len(a)-1,0,-1):
        if a[i] >= a[i-1]:
            print(a,'No') 
            break
    else:    
        print(a,'Yes')  
    
    # пробежка с начала, но проверка того же самого возрастания с начала последовательности
    for i in range(len(a) - 1):
        if a[i] <= a[i+1]:
            print(a,'No') 
            break
    else:    
        print(a,'Yes')
    
    # однострочник, по алгоритму неоптимальный так как пробегается по всем элементам
    print(a,['No','Yes'][all([a[i] > a[i+1] for i in range(len(a) - 1)])])
    # c кастингом в int
    #print(a,['No','Yes'][all([int(a[i]) > int(a[i+1]) for i in range(len(a) - 1)])])
1
Эксперт Pascal/Delphi
 Аватар для droider
4888 / 2822 / 865
Регистрация: 04.10.2012
Сообщений: 10,264
10.11.2021, 09:42
Оставлю это здесь.

Python
1
2
3
4
5
6
7
8
x = int(input())
result = 'YES'
while x // 10 != 0:
    n = x % 10
    x = x // 10
    if n >= x % 10:
       result = 'NO'
print(result)
Для знакомого тоже решал эту задачу
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
12.11.2021, 13:32
droider, единственное что могу добавить:
Python
1
2
3
4
5
6
7
8
x = int(input())
result = 'YES'
while x // 10 != 0:
    x, n = divmod(x, 10)    # Немного сократим
    if n >= x % 10:
       result = 'NO'
       break                # Нет смысла продолжать проверку
print(result)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.11.2021, 13:32
Помогаю со студенческими работами здесь

Дано натуральное число. Установить, является ли последовательность его цифр при просмотре их справа налево упорядоченной
Дано натуральное число. Установить, является ли последовательность его цифр при просмотре их справа налево упорядоченной по...

Дано натуральное число. Установить, является ли последовательность его цифр при просмотре их справа налево упорядоченной
Дано натуральное число. Установить, является ли последовательность его цифр при просмотре их справа налево упорядоченной по возрастанию. ...

Дано натуральное число.Установить,является ли последовательность его цифр при просмотре их справа налево упорядоченной
int a; bool flag; a = int.Parse(Console.ReadLine()); flag = true; while (a &gt; 9) { ...

Дано натуральное число. Установить. является ли последовательность его цифр при просмотре справа налево упорядоченной
Упорядоченной по возрастанию. Например 54321 - ответ положительный, 76841 - отрицательный

Выяснить ,является ли последовательность цифр числа при просмотре справа налево возрастающей
Дано натуральное число N,не превосходящее 1000000.Требуется выяснить ,является ли последовательность цифр данного числа при просмотре...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru