Open In App

Python code to move spaces to front of string in single traversal

Last Updated : 23 Mar, 2023
Improve
Improve
Like Article
Like
Save
Share
Report

Given a string that has set of words and spaces, write a program to move all spaces to front of string, by traversing the string only once. Examples:

Input  : str = "geeks for geeks"
Output : str = "  geeksforgeeks"

Input  : str = "move these spaces to beginning"
Output : str = "    movethesespacestobeginning"
There were four space characters in input,
all of them should be shifted in front. 

This problem has existing solution, please refer Move spaces to front of string in single traversal link. We will solve this problem quickly in Python using List Comprehension

Approach 1:

  1. Traverse input string and create a string without any space character using list comprehension.
  2. Now to know how many space characters were there in original string just take a difference of length of original string and new string.
  3. Now create another string and append space characters at the beginning.

Implementation

Python3




# Function to move spaces to front of string
# in single traversal in Python
 
def moveSpaces(input):
     
    # Traverse string to create string without spaces
    noSpaces = [ch for ch in input if ch!=' ']
 
    # calculate number of spaces
    space= len(input) - len(noSpaces)
 
    # create result string with spaces
    result = ' '*space
 
    # concatenate spaces with string having no spaces
    result = '"'+result + ''.join(noSpaces)+'"'
    print (result)
 
# Driver program
if __name__ == "__main__":
    input = 'geeks for geeks'
    moveSpaces(input)


Output

"  geeksforgeeks"

Time Complexity: O(n)
Auxiliary Space: O(n)

Approach 2 : Using count() and replace() methods

Implementation

Python3




# Function to move spaces to front of string
# in single traversal in Python
 
def moveSpaces(input):
    c=input.count(' ')
    input=input.replace(' ','')
    input=' '*c+input
    print(input)
 
# Driver program
if __name__ == "__main__":
    input = 'geeks for geeks'
    moveSpaces(input)


Output

  geeksforgeeks

Time complexity: O(n), where n is the length of the input string.
Auxiliary space: O(n), as the function creates a new string of length n (where n is the length of the input string) to store the modified string with spaces moved to the front. 

Approach 3 : Using operator.countOf() and replace() methods

Python3




# Function to move spaces to front of string
# in single traversal in Python
 
def moveSpaces(input):
    import operator
    c=operator.countOf(input,' ')
    input=input.replace(' ','')
    input=' '*c+input
    print(input)
 
# Driver program
if __name__ == "__main__":
    input = 'geeks for geeks'
    moveSpaces(input)


Output

  geeksforgeeks

Time Complexity : O(N)
Auxiliary Space : O(1)

Approach 5: Using join() and split() methods

  • Split the input string into a list of words using the split() method.
  • Join the list of words using the join() method to form a new string without any space characters.
  • Append the required number of space characters at the beginning of the modified string.
  • Return the modified string.

Python3




def moveSpaces(input):
    words = input.split()
    modified_str = ''.join(words)
    num_spaces = len(input) - len(modified_str)
    modified_str = ' ' * num_spaces + modified_str
    return modified_str
 
# Driver program
if __name__ == "__main__":
    input_str = 'geeks for geeks'
    print(moveSpaces(input_str))


Output

  geeksforgeeks

Time complexity: O(n), where n is the length of the input string.
Auxiliary space: O(n), where n is the length of the input string (to store the list of words and the modified string).

Approach 6: Using regular expressions

Algorithm:

  • The input string is passed to the function moveSpaces() as input_str.
  • The re.sub() method is used to replace all occurrences of a space with an empty string in the input_str. The modified string is then stored in the variable modified_str.
  • The number of spaces in the original input string is calculated by taking the difference between the length of input_str and the length of modified_str.
  • The required number of spaces is added at the beginning of the modified string using the multiplication operator and the ‘ ‘ (space) character. The modified
  • string is then stored back in the variable modified_str.
  • The modified string is returned as the output of the function.
  • Finally, the moveSpaces() function is called with the input string ‘geeks for geeks’ and the output is printed.

Python3




import re
 
def moveSpaces(input_str):
  # Replace all occurrences of space with empty string
  modified_str = re.sub(' ', '', input_str)
  # Get the number of spaces in the original string
  num_spaces = len(input_str) - len(modified_str)
  # Add the required number of spaces at the beginning of the modified string
  modified_str = ' ' * num_spaces + modified_str
 
  return modified_str
input_str = 'geeks for geeks'
print(moveSpaces(input_str))


Output

  geeksforgeeks

Time complexity: O(n), where n is the length of the input string. The regular expression re.sub() method used in this approach has a time complexity of O(n), where n is the length of the input string.

Space complexity: O(n), where n is the length of the input string. This is because the re.sub() method creates a new string with all spaces removed, which is stored in memory before being used to calculate the number of spaces in the original string and add the required number of spaces at the beginning of the modified string.



Similar Reads

Move spaces to front of string in single traversal
Given a string that has set of words and spaces, write a program to move all spaces to front of string, by traversing the string only once. Examples: Input : str = "geeks for geeks" Output : str = " geeksforgeeks" Input : str = "move these spaces to beginning" Output : str = " movethesespacestobeginning" There were four space characters in input, a
6 min read
std::move in Utility in C++ | Move Semantics, Move Constructors and Move Assignment Operators
Prerequisites: lvalue referencervalue referenceCopy Semantics (Copy Constructor) References: In C++ there are two types of references- lvalue reference:An lvalue is an expression that will appear on the left-hand side or on the right-hand side of an assignment.Simply, a variable or object that has a name and memory address.It uses one ampersand (
11 min read
Move all zeroes to end of array | Set-2 (Using single traversal)
Given an array of n numbers. The problem is to move all the 0's to the end of the array while maintaining the order of the other elements. Only single traversal of the array is required.Examples: Input : arr[] = {1, 2, 0, 0, 0, 3, 6} Output : 1 2 3 6 0 0 0 Input: arr[] = {0, 1, 9, 8, 4, 0, 0, 2, 7, 0, 6, 0, 9} Output: 1 9 8 4 2 7 6 9 0 0 0 0 0 Algo
7 min read
C++ Program to Move all zeroes to end of array | Set-2 (Using single traversal)
Given an array of n numbers. The problem is to move all the 0's to the end of the array while maintaining the order of the other elements. Only single traversal of the array is required.Examples:   Input : arr[] = {1, 2, 0, 0, 0, 3, 6} Output : 1 2 3 6 0 0 0 Input: arr[] = {0, 1, 9, 8, 4, 0, 0, 2, 7, 0, 6, 0, 9} Output: 1 9 8 4 2 7 6 9 0 0 0 0 0
2 min read
Java Program to Move all zeroes to end of array | Set-2 (Using single traversal)
Given an array of n numbers. The problem is to move all the 0's to the end of the array while maintaining the order of the other elements. Only single traversal of the array is required.Examples:   Input : arr[] = {1, 2, 0, 0, 0, 3, 6} Output : 1 2 3 6 0 0 0 Input: arr[] = {0, 1, 9, 8, 4, 0, 0, 2, 7, 0, 6, 0, 9} Output: 1 9 8 4 2 7 6 9 0 0 0 0 0
2 min read
Python3 Program to Move all zeroes to end of array | Set-2 (Using single traversal)
Given an array of n numbers. The problem is to move all the 0's to the end of the array while maintaining the order of the other elements. Only single traversal of the array is required.Examples:   Input : arr[] = {1, 2, 0, 0, 0, 3, 6} Output : 1 2 3 6 0 0 0 Input: arr[] = {0, 1, 9, 8, 4, 0, 0, 2, 7, 0, 6, 0, 9} Output: 1 9 8 4 2 7 6 9 0 0 0 0 0
2 min read
Javascript Program to Move all zeroes to end of array | Set-2 (Using single traversal)
Given an array of n numbers. The problem is to move all the 0's to the end of the array while maintaining the order of the other elements. Only single traversal of the array is required.Examples:   Input : arr[] = {1, 2, 0, 0, 0, 3, 6} Output : 1 2 3 6 0 0 0 Input: arr[] = {0, 1, 9, 8, 4, 0, 0, 2, 7, 0, 6, 0, 9} Output: 1 9 8 4 2 7 6 9 0 0 0 0 0
2 min read
Move last element to front of a given Linked List
Write a function that moves the last node to the front in a given Singly Linked List. Examples: Input: 1->2->3->4->5Output: 5->1->2->3->4 Input: 3->8->1->5->7->12Output: 12->3->8->1->5->7 Approach: To solve the problem follow the below idea: Traverse the list till the last node. Use two pointers
11 min read
Move To Front Data Transform Algorithm
What is the MTF transform? The MTF (Move to Front) is a data transformation algorithm that restructures data in such a way that the transformed message is more compressible and therefore used as an extra step in compression. Technically, it is an invertible transform of a sequence of input characters to an array of output numbers. Why MTF? In many
9 min read
Queries to search an element in an array and move it to front after every query
Given an integer M which represents an array initially having numbers 1 to M. Also given is a Query array. For every query, search the number in the initial array and bring it to the front of the array. The task is to return the indexes of the searched element in the given array for every query.Examples: Input : Q[] = {3, 1, 2, 1}, M = 5 Output : [
15 min read
Practice Tags :
three90RightbarBannerImg