Skip to content

Sort data on a stack with a limited set of instructions. Project from 42 São Paulo

Notifications You must be signed in to change notification settings

vitoriagalli/push_swap

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PUSH_SWAP

Introduction

Game rules

The game is composed of 2 stacks named A and B. The goal is to sort in ascending order the stack A with the minimum possible number of operations. To do this you have the following operations at your disposal

operation description
sa swap a - swap the first 2 elements at the top of stack_a
sb swap b - swap the first 2 elements at the top of stack_b
ss sa and sb at the same time
pa push a - take the first element at the top of b and put it at the top of a
pb push b - take the first element at the top of a and put it at the top of b
ra rotate a - shift up all elements of stack_a by 1. The first element becomes the last one
rb rotate b - shift up all elements of stack_b by 1. The first element becomes the last one
rr ra and rb at the same time
rra reverse rotate a - shift down all elements of stack_a by 1. The last element becomes the first one
rrb reverse rotate b - shift down all elements of stack_b by 1. The last element becomes the first one
rrr rra and rrb at the same time

Usage

Build Instructions

$ git clone https://github.com/vscabell/push_swap
$ cd push_swap
$ make
Mandatory

The push_swap program must display the smallest list of instructions possible to sort the stack A

$ make
...
$ ./push_swap 5 3 1
sa
rra
Bonus

The checker program will read instructions on the standard input, each instruction will be followed by ’\n’. When EOF is triggered, the program will execute them and display if the resulting list is sorted

$ make bonus
...
$ ./checker 5 3 1
sa
rra
OK

checker is also available with the verbose -v flag

$ ./checker -v 5 3 1

size:   3       0
stack:  5
        3
        1
        _       _
        a       b
> sa

size:   3       0
stack:  3
        5
        1
        _       _
        a       b
> rra

size:   3       0
stack:  1
        3
        5
        _       _
        a       b
> OK

other commands

$ make test

for the 42 students

$ make norm

Algorithm

The implemented algorithm was inspired by the following wiki, which explain all the steps to sort the stack.

I executed simpler and less performative version, although faster since the markup mode is checked only by index. The step to find out if swap (sa) is necessary was not executed as well.

With this push_swap_visualizer you can follow the operations and the algorithm behavior.

visualizer
sorting 100 random valid values

About

Sort data on a stack with a limited set of instructions. Project from 42 São Paulo

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published