Skip to content
    geeksforgeeks
    • Interview Prep
      • DSA
      • Interview Corner
      • Aptitude & Reasoning
      • Practice Coding Problems
      • All Courses
    • Tutorials
      • Python
      • Java
      • ML & Data Science
      • Programming Languages
      • Web Development
      • CS Subjects
      • DevOps
      • Software and Tools
      • School Learning
    • Tracks
      • Languages
        • Python
        • C
        • C++
        • Java
        • Advanced Java
        • SQL
        • JavaScript
        • C#
      • Interview Preparation
        • GfG 160
        • GfG 360
        • System Design
        • Core Subjects
        • Interview Questions
        • Interview Puzzles
        • Aptitude and Reasoning
        • Product Management
        • Computer Organisation and Architecture
      • Data Science
        • Python
        • Data Analytics
        • Complete Data Science
        • Gen AI
        • Agentic AI
      • Dev Skills
        • Full-Stack Web Dev
        • DevOps
        • Software Testing
        • CyberSecurity
        • NextJS
        • Git
      • Tools
        • Computer Fundamentals
        • AI Tools
        • MS Excel & Google Sheets
        • MS Word & Google Docs
      • Maths
        • Maths For Computer Science
        • Engineering Mathematics
        • School Maths
    • Python Tutorial
    • Data Types
    • Interview Questions
    • Examples
    • Quizzes
    • DSA Python
    • Data Science
    • NumPy
    • Pandas
    • Practice
    • Django
    • Flask
    • Projects
    Open In App

    Python - Split Numeric String into K digit integers

    Last Updated : 13 Apr, 2023
    Comments
    Improve
    Suggest changes
    Like Article
    Like
    Report
    See More

    Given a String, convert it to K digit integers

    Input : test_str = '457336', K = 2 

    Output : [45, 73, 36] 

    Explanation : Divided in 2 digit integers. 

    Input : test_str = '457336', K = 3 

    Output : [457, 336] 

    Explanation : Divided in 3 digit integers.

    Method #1 : Using int() + slice + loop

    In this, we iterate for string and perform slicing till K digits and then perform task of conversion to integer using int().

    Python3
    # Python3 code to demonstrate working of 
    # Split Numeric String into K digit integers
    # Using int() + slice + loop
    
    # initializing string
    test_str = '457336842'
    
    # printing original string
    print("The original string is : " + str(test_str))
    
    # initializing substring
    K = 3
    
    res = []
    for idx in range(0, len(test_str), K):
        
        # converting to int, after slicing
        res.append(int(test_str[idx : idx + K]))
    
    # printing result 
    print("Converted number list : " + str(res)) 
    

    Output
    The original string is : 457336842
    Converted number list : [457, 336, 842]

    Time Complexity: O(n), where n is the length of the input list. 
    Auxiliary Space: O(n) additional space of size n is created where n is the number of elements in the list “test_list”. 

    Method #2 : Using list comprehension + int() + slicing

    Similar method to above, just a shorthand to solve this problem.

    Python3
    # Python3 code to demonstrate working of 
    # Split Numeric String into K digit integers
    # Using list comprehension + int() + slicing
    
    # initializing string
    test_str = '457336842'
    
    # printing original string
    print("The original string is : " + str(test_str))
    
    # initializing substring
    K = 3
    
    # one liner to solve problem
    res = [int(test_str[idx : idx + K]) for idx in range(0, len(test_str), K)]
    
    # printing result 
    print("Converted number list : " + str(res)) 
    

    Output
    The original string is : 457336842
    Converted number list : [457, 336, 842]

    Time Complexity: O(n)

    Auxiliary Space: O(n)

    Method #3 : Using regex:

    1. Import the re module to use regular expressions.
    2. Define the input string test_str and the number of digits K in each substring.
    3. Use re.findall() to find all substrings of test_str that contain exactly K digits.
    4. Use . to match any character, and * to match zero or more occurrences of the preceding character or group.
      The pattern .*K matches any K characters.
    5. Use re.findall() to find all substrings in test_str that match the pattern.
    6. re.findall() returns a list of strings, where each string has K characters.
    7. Use map() to convert each substring in the resulting list to an integer.
    8. map() applies the int() function to each element in the list.
    9. The resulting list contains integers instead of strings.
    10. Store the resulting list of integers in res.
    11. Print the list res.
    Python3
    import re
    # Define the input string and the number of digits in each substring
    test_str = '457336842'
    # printing original string
    print("The original string is : " + str(test_str))
     
    K = 3
    # Use regular expression to find all K-digit substrings
    res = list(map(int, re.findall('.'*K, test_str)))
    
    # printing result
    print("Converted number list : " + str(res))
    #This code is contributed by Jyothi Pinjala.
    

    Output
    The original string is : 457336842
    Converted number list : [457, 336, 842]

    The time complexity : O(n/K), where n is the length of the input string test_str. The re.findall() method iterates over the input string in steps of K, and each iteration takes constant time to find the K-character substring. Therefore, the time complexity of re.findall() is O(n/K), and the overall time complexity of the algorithm is also O(n/K).

    The auxiliary space :O(n/K) because the resulting list contains n/K elements, each with K digits. The space required to store each element is proportional to K, so the overall space complexity is proportional to n/K * K, which simplifies to O(n/K). Additionally, the re.findall() method may allocate additional memory to store the intermediate results of its search, but this memory usage is also proportional to n/K and is dominated by the space required to store the resulting list.

    Method 4: Using recursion

    Step-by-step approach 

    • Define a recursive function split_string that takes a string s and an integer k as arguments.
    • The base case of the recursive function is when the input string s is empty. In this case, return an empty list [].
    • In the recursive case, split the input string s into a K digit substring and the rest of the string using slicing s[:k] and s[k:], respectively.
    • Convert the K digit substring to an integer using int() and append it to the result of the recursive call to split_string() on the rest of the string.
    • Call the recursive function split_string with the input string test_str and substring length K as arguments, and store the result in the variable res.
    • Print the result of the function using print("Converted number list : " + str(res)).
    Python3
    # initializing string
    test_str = '457336842'
    
    # printing original string
    print("The original string is : " + str(test_str))
    
    # initializing substring
    K = 3
    
    # defining recursive function to split string
    def split_string(s, k):
        # base case: if string is empty, return empty list
        if not s:
            return []
        # recursive case: split the string into K digit integers and append to results list
        return [int(s[:k])] + split_string(s[k:], k)
    
    # call the recursive function
    res = split_string(test_str, K)
    
    # printing result
    print("Converted number list : " + str(res))
    

    Output
    The original string is : 457336842
    Converted number list : [457, 336, 842]

    Time complexity: O(n/K) where n is the length of the input string.
    Auxiliary space: O(n/K) in the worst case.

    Create Quiz

    M

    manjeet_04
    Improve

    M

    manjeet_04
    Improve
    Article Tags :
    • Python
    • Python Programs
    • Python list-programs
    • Python string-programs

    Explore

      Python Fundamentals

      Python Introduction

      2 min read

      Input and Output in Python

      4 min read

      Python Variables

      4 min read

      Python Operators

      4 min read

      Python Keywords

      2 min read

      Python Data Types

      8 min read

      Conditional Statements in Python

      3 min read

      Loops in Python - For, While and Nested Loops

      5 min read

      Python Functions

      5 min read

      Recursion in Python

      4 min read

      Python Lambda Functions

      5 min read

      Python Data Structures

      Python String

      5 min read

      Python Lists

      4 min read

      Python Tuples

      4 min read

      Python Dictionary

      3 min read

      Python Sets

      6 min read

      Python Arrays

      7 min read

      List Comprehension in Python

      4 min read

      Advanced Python

      Python OOP Concepts

      11 min read

      Python Exception Handling

      5 min read

      File Handling in Python

      4 min read

      Python Database Tutorial

      4 min read

      Python MongoDB Tutorial

      3 min read

      Python MySQL

      9 min read

      Python Packages

      10 min read

      Python Modules

      3 min read

      Python DSA Libraries

      15 min read

      List of Python GUI Library and Packages

      3 min read

      Data Science with Python

      NumPy Tutorial - Python Library

      3 min read

      Pandas Tutorial

      4 min read

      Matplotlib Tutorial

      5 min read

      Python Seaborn Tutorial

      3 min read

      StatsModel Library - Tutorial

      3 min read

      Learning Model Building in Scikit-learn

      6 min read

      TensorFlow Tutorial

      2 min read

      PyTorch Tutorial

      6 min read

      Web Development with Python

      Flask Tutorial

      8 min read

      Django Tutorial | Learn Django Framework

      7 min read

      Django ORM - Inserting, Updating & Deleting Data

      4 min read

      Templating With Jinja2 in Flask

      6 min read

      Django Templates

      5 min read

      Build a REST API using Flask - Python

      3 min read

      Building a Simple API with Django REST Framework

      3 min read

      Python Practice

      Python Quiz

      1 min read

      Python Coding Practice

      1 min read

      Python Interview Questions and Answers

      15+ min read
    top_of_element && top_of_screen < bottom_of_element) || (bottom_of_screen > articleRecommendedTop && top_of_screen < articleRecommendedBottom) || (top_of_screen > articleRecommendedBottom)) { if (!isfollowingApiCall) { isfollowingApiCall = true; setTimeout(function(){ if (loginData && loginData.isLoggedIn) { if (loginData.userName !== $('#followAuthor').val()) { is_following(); } else { $('.profileCard-profile-picture').css('background-color', '#E7E7E7'); } } else { $('.follow-btn').removeClass('hideIt'); } }, 3000); } } }); } $(".accordion-header").click(function() { var arrowIcon = $(this).find('.bottom-arrow-icon'); arrowIcon.toggleClass('rotate180'); }); }); window.isReportArticle = false; function report_article(){ if (!loginData || !loginData.isLoggedIn) { const loginModalButton = $('.login-modal-btn') if (loginModalButton.length) { loginModalButton.click(); } return; } if(!window.isReportArticle){ //to add loader $('.report-loader').addClass('spinner'); jQuery('#report_modal_content').load(gfgSiteUrl+'wp-content/themes/iconic-one/report-modal.php', { PRACTICE_API_URL: practiceAPIURL, PRACTICE_URL:practiceURL },function(responseTxt, statusTxt, xhr){ if(statusTxt == "error"){ alert("Error: " + xhr.status + ": " + xhr.statusText); } }); }else{ window.scrollTo({ top: 0, behavior: 'smooth' }); $("#report_modal_content").show(); } } function closeShareModal() { const shareOption = document.querySelector('[data-gfg-action="share-article"]'); shareOption.classList.remove("hover_share_menu"); let shareModal = document.querySelector(".hover__share-modal-container"); shareModal && shareModal.remove(); } function openShareModal() { closeShareModal(); // Remove existing modal if any let shareModal = document.querySelector(".three_dot_dropdown_share"); shareModal.appendChild(Object.assign(document.createElement("div"), { className: "hover__share-modal-container" })); document.querySelector(".hover__share-modal-container").append( Object.assign(document.createElement('div'), { className: "share__modal" }), ); document.querySelector(".share__modal").append(Object.assign(document.createElement('h1'), { className: "share__modal-heading" }, { textContent: "Share to" })); const socialOptions = ["LinkedIn", "WhatsApp","Twitter", "Copy Link"]; socialOptions.forEach((socialOption) => { const socialContainer = Object.assign(document.createElement('div'), { className: "social__container" }); const icon = Object.assign(document.createElement("div"), { className: `share__icon share__${socialOption.split(" ").join("")}-icon` }); const socialText = Object.assign(document.createElement("span"), { className: "share__option-text" }, { textContent: `${socialOption}` }); const shareLink = (socialOption === "Copy Link") ? Object.assign(document.createElement('div'), { role: "button", className: "link-container CopyLink" }) : Object.assign(document.createElement('a'), { className: "link-container" }); if (socialOption === "LinkedIn") { shareLink.setAttribute('href', `https://www.linkedin.com/sharing/share-offsite/?url=${window.location.href}`); shareLink.setAttribute('target', '_blank'); } if (socialOption === "WhatsApp") { shareLink.setAttribute('href', `https://api.whatsapp.com/send?text=${window.location.href}`); shareLink.setAttribute('target', "_blank"); } if (socialOption === "Twitter") { shareLink.setAttribute('href', `https://twitter.com/intent/tweet?url=${window.location.href}`); shareLink.setAttribute('target', "_blank"); } shareLink.append(icon, socialText); socialContainer.append(shareLink); document.querySelector(".share__modal").appendChild(socialContainer); //adding copy url functionality if(socialOption === "Copy Link") { shareLink.addEventListener("click", function() { var tempInput = document.createElement("input"); tempInput.value = window.location.href; document.body.appendChild(tempInput); tempInput.select(); tempInput.setSelectionRange(0, 99999); // For mobile devices document.execCommand('copy'); document.body.removeChild(tempInput); this.querySelector(".share__option-text").textContent = "Copied" }) } }); // document.querySelector(".hover__share-modal-container").addEventListener("mouseover", () => document.querySelector('[data-gfg-action="share-article"]').classList.add("hover_share_menu")); } function toggleLikeElementVisibility(selector, show) { document.querySelector(`.${selector}`).style.display = show ? "block" : "none"; } function closeKebabMenu(){ document.getElementById("myDropdown").classList.toggle("show"); }
geeksforgeeks-footer-logo
Corporate & Communications Address:
A-143, 7th Floor, Sovereign Corporate Tower, Sector- 136, Noida, Uttar Pradesh (201305)
Registered Address:
K 061, Tower K, Gulshan Vivante Apartment, Sector 137, Noida, Gautam Buddh Nagar, Uttar Pradesh, 201305
GFG App on Play Store GFG App on App Store
  • Company
  • About Us
  • Legal
  • Privacy Policy
  • Contact Us
  • Advertise with us
  • GFG Corporate Solution
  • Campus Training Program
  • Explore
  • POTD
  • Job-A-Thon
  • Blogs
  • Nation Skill Up
  • Tutorials
  • Programming Languages
  • DSA
  • Web Technology
  • AI, ML & Data Science
  • DevOps
  • CS Core Subjects
  • Interview Preparation
  • Software and Tools
  • Courses
  • ML and Data Science
  • DSA and Placements
  • Web Development
  • Programming Languages
  • DevOps & Cloud
  • GATE
  • Trending Technologies
  • Videos
  • DSA
  • Python
  • Java
  • C++
  • Web Development
  • Data Science
  • CS Subjects
  • Preparation Corner
  • Interview Corner
  • Aptitude
  • Puzzles
  • GfG 160
  • System Design
@GeeksforGeeks, Sanchhaya Education Private Limited, All rights reserved
Lightbox
Improvement
Suggest Changes
Help us improve. Share your suggestions to enhance the article. Contribute your expertise and make a difference in the GeeksforGeeks portal.
geeksforgeeks-suggest-icon
Create Improvement
Enhance the article with your expertise. Contribute to the GeeksforGeeks community and help create better learning resources for all.
geeksforgeeks-improvement-icon
Suggest Changes
min 4 words, max Words Limit:1000

Thank You!

Your suggestions are valuable to us.

What kind of Experience do you want to share?

Interview Experiences
Admission Experiences
Career Journeys
Work Experiences
Campus Experiences
Competitive Exam Experiences