Algorithm


Problem Name: Python - Standardize Mobile Number Using Decorators

Problem Link: https://www.hackerrank.com/challenges/standardize-mobile-number-using-decorators/problem?isFullScreen=true  

In this HackerRank Functions in PYTHON problem solution,

Let's dive into decorators! You are given N mobile numbers. Sort them in ascending order then print them in the standard format shown below:

+91 xxxxx xxxxx


The given mobile numbers may have +91,91 or 0 written before the actual 10 digit number. Alternatively, there may not be any prefix at all.

Input Format

The first line of input contains an integer N, the number of mobile phone numbers.

N lines follow each containing a mobile number.

Output Format

Print N mobile numbers on separate lines in the required format.

Sample Input

3
07895462130
919875641230
9195969878

Sample Output

+91 78954 62130
+91 91959 69878
+91 98756 41230

Concept

Like most other programming languages, Python has the concept of closures. Extending these closures gives us decorators, which are an invaluable asset. You can learn about decorators in 12 easy steps here.
To solve the above question, make a list of the mobile numbers and pass it to a function that sorts the array in ascending order. Make a decorator that standardizes the mobile numbers and apply it to the function.

 

 

 

 

Code Examples

#1 Code Example with Python Programming

Code - Python Programming


def wrapper(f):
    def fun(l):
        # complete the function
        f(["+91 " + c[-10:-5] + " " + c[-5:] for c in l])
    return fun
Copy The Code & Try With Live Editor
Advertisements

Demonstration


Previous
[Solved] XML2 - Find the Maximum Depth in PYTHON solution in Hackerrank
Next
[Solved] Decorators 2 - Name Directory in PYTHON solution in Hackerrank