Speed up Python Code

Speed up Python Code:


Python is one of the most popular programming languages all over the world. For its, simple syntax and rich library, it is being used in competitive programming also. Most of us probably started coding with python. At first, everything goes simple and easy. But while solving a hard algorithmic problems, most of us suffer from Time Limit Exceeded. However, it is not a problem of python; most of the cases, the problem is with the programmer. I am not saying that python is not slow, but if a programmer writes efficient programme, it will get Accepted for sure. Here are some tips to speed up your python programme.

Use proper data structures

Use of proper data structure has a significant effect on runtime. Python has list, tuple, set and dictionary as the built-in data structures. However, most of the people use the list in all cases. But it is not a right choice. Use proper data structures depending on your task. Especially use a tuple instead of a list. Because iterating over tuple is easier than iterating over a list.

Decrease the use of for loop

As for loop is dynamic in python, it takes more time than while loop. So, use while loop instead of for loop.

Use list comprehension

Do not use any other technique if you can use list comprehension. For example, here is a code to list all the numbers between 1 and 1000 that is the multiplier of 3:

L = []
for i in range (1, 1000):
    if i%3 == 0:
        L.append (i)

Using list comprehension, it would be:

L = [i for i in range (1, 1000) if i%3 == 0]

List comprehension works faster than using the append method.

Use multiple assignments

Do not assaign variables like this:

a = 2
b = 3
c = 5
d = 7

Instead, assign variables like this:

a, b, c, d = 2, 3, 5, 7

Do not use global variables

Python has global keyword to declare global variables. But global variables take higher time during operation than a local variable. So, do not use global variables if it is not necessary.

Use library functions

Do not write your function (manually) if it is already in the library. Library functions are highly efficient, and you will probably won’t be able to code with that efficiency.

Concatenate strings with join In python, you can concatenate strings with + operation.

concatenatedString = "Programming " + "is " + "fun."

It can also be done with join() method.

concatenatedString = " ".join (["Programming", "is", "fun."])

join() concatenates strings faster than + operation because + operators create a new string and then copies the old content at each step. But join() doesn’t work that way.

Use generators

If you have a large amount of data in your list and you need to use one data at a time and for once then use generators. It will save you time.

Avoid dot operation as much as possible

Try to avoid dot operation. See the below programme.

import math
val = math.sqrt(60)

Instead of the above style write code like this:

from math import sqrt
val = sqrt(60)

Because when you call a function using . (dot) it first calls __getattribute()__ or __getattr()__ which then use dictionary operation which costs time. So, try using from module import function.

Use 1 for infinity loops

Use while 1 instead of while True. It will reduce some runtime.

Think outside the box

Try new ways to write your code efficiently. See the below code.

if a_condition:
    if another_condition:
    raise exception

Instead of the above code you can write:

if (not a_condition) or (not another_condition):
    raise exception

Use speed up applications

For python’s slow speed, some projects have been taken to decrease runtime. Pypy and Numba two of them. In most of the programming contests, you will see pypy if it allows python. These applications will reduce the runtime of your programme.

Use special libraries to process large datasets

C/C++ is faster than python. So, many packages and modules have been written in C/C++ that you can use in your python programme. NumpyScipy and Pandas are three of them and are popular for processing large datasets.

Use the latest release of python

Python is updated and upgraded regularly, and every release is faster and more optimized. So always use the latest version of python.

These were some of the tips to decrease the runtime of python code. There are a few more techniques that you can use. Use a search engine to find those and write efficient code!

from Tumblr https://generouspiratequeen.tumblr.com/post/635472039765032960

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out /  Change )

Google photo

You are commenting using your Google account. Log Out /  Change )

Twitter picture

You are commenting using your Twitter account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )

Connecting to %s