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

Как сократить алгоритм , что бы ускорить время выполнения

14.01.2016, 13:45. Показов 4733. Ответов 23

Студворк — интернет-сервис помощи студентам
Всем Доброго времени суток

Подскажите пожалуйста как можно преобразовать код , либо сократить его для быстродействия?

Исходный код :
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import time
 
num0 = 0
num1 = 0 
num2 = 0
num3 = 0
num4 = 0
num5 = 0
num_end = 62
num = [num0 , num1 , num2 , num3 , num4 , num5]
 
t = time.asctime()
print (t)
while True:
    print (num)
    num5 += 1
    num = [num0 , num1 , num2 , num3 , num4 , num5]
    password = ""
    if num5 == num_end:
        num5 = 0
        num4 += 1
        if num4 == num_end:
            num3 += 1
            num4 = 0
            if num3 == num_end:
                num2+= 1
                num3 = 0
                if num2 == num_end:
                    num1 += 1
                    num2 = 0
                    if num1 == num_end:
                        num0 += 1
                        num1 = 0
                        if num0 == num_end:
                            print("End")
                            t = time.asctime()
                            print (t)
                            break
  • Возможно есть какие то методы или процедуры?
  • Так же хотелось бы узнать как можно по другому подсчитать время выполнения?
Желательно с подробным пояснением

# Начал изучать язык относительно недавно
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.01.2016, 13:45
Ответы с готовыми решениями:

Как сократить время выполнения
def test(word1, word2): return sorted(word1) == sorted(word2) n = int(input()) words = for i in range(n): word =...

Как сократить время выполнения программы?
#include <iostream> #include <string> using namespace std; int main(){ string S; string T; string A; cin >> S; int...

A^b mod m. Как сократить время выполнения ?
Здравствуйте! Рабочий код (вроде), но при проверке разные ошибки типа превышения времени ожидания и тп. Помогите разобраться в чем...

23
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
14.01.2016, 22:59
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от AvisMortes Посмотреть сообщение
сколько чисел возможно получить из перестановки шести элементов списка принимающие значения от 0 до 62
https://www.cyberforum.ru/cgi-bin/latex.cgi?{63}^{6}, не?
1
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,182
Записей в блоге: 6
15.01.2016, 08:31
Цитата Сообщение от AvisMortes Посмотреть сообщение
А для чего служит xrange?
Такие вопросы задавать на форуме неприлично, для этого есть даже не гугль, а просто официальная документация.

Цитата Сообщение от AvisMortes Посмотреть сообщение
И как можно проверить работу циклов(например: выводом сообщений об изменениях)?
"Изменения" подразумеваются в списке, но я сильно сомневаюсь, что вам нужен именно список. Впрочем, если хотите - то пожалуйста:
Python
1
2
3
4
5
6
7
8
for num0 in xrange(63):
    for num1 in xrange(63):
        for num2 in xrange(63):
            for num3 in xrange(63):
                for num4 in xrange(63):
                    for num5 in xrange(63):
                        lst = [num0, num1, num2, num3, num4, num5]
                        print lst
1
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
15.01.2016, 18:05
Ещё немного упростил
Python
1
2
3
4
5
6
7
8
9
10
n = [0] * 6
i = len(n) - 1
while not all(x == 62 for x in n):
     while n[i] == 63:
         n[i] = 0
         i -= 1
         n[i] += 1
     else:
         i = len(n) - 1
     n[i] += 1
1
2838 / 1647 / 254
Регистрация: 03.12.2007
Сообщений: 4,222
16.01.2016, 20:05
Это же увеличение числа на 1 в системе по основанию 63. Если использовать более традиционное представление чисел, можно ещё упростить:
Python
1
2
for i in range(63 ** 6):
    i
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.01.2016, 20:05
Помогаю со студенческими работами здесь

Как сократить время выполнения кода:
main = input() main = main.split() gg = set() for i in range(int(main)): days = input() days = days.split() pp = ...

Как можно сократить время выполнения кода?
#include <iostream> #include <string> using namespace std; int main(){ string S; string T; string A; cin >> S; int...

Как ускорить время выполнения запроса
Здравствуйте, как можно ускорить данный запрос: SELECT id, surname, CASE WHEN ball < 60 THEN 'Низкий' WHEN ball BETWEEN...

Как ускорить время выполнения программы
Добрый день :) Исходные данные В единственной строке находится целое число N, 1 ≤ N ≤ 10^9. Результат Следует...

Как ускорить время выполнения и уменьшить вес программы?
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using...


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru