Skip to content

Optimizing stack sorting with limited set of instructions.

Notifications You must be signed in to change notification settings

khabibullet/push-swap

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PUSH_SWAP

Push_swap calculates and displays on the standard output the smallest program, made of Push swap language instructions, that sorts the integers received as arguments.

We have 2 stacks named a and b. At the beginning: the stack a contains a random amount of negative and/or positive numbers which cannot be duplicated, the stack b is empty.

The goal is to sort in ascending order numbers into stack a. To do so we have the following operations at our disposal:

sa (swap a): Swap the first 2 elements at the top of stack a. Do nothing if there is only one or no elements.

sb (swap b): Swap the first 2 elements at the top of stack b. Do nothing if there is only one or no elements.

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. Do nothing if b is empty.

pb (push b): Take the first element at the top of a and put it at the top of b. Do nothing if a is empty.

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.

drawing

Platform

macOS (x86).

Instruments

Self-written libc functions library "libft" is used due to educational subject restrictions as well as readline analogue "get_next_line" and simplified version of printf "ft_printf".

Source files are lintered by "42 Norminette" linter.

Visualizer by o-reo is also used to visualize instructions given by push_swap output.

Usage

Building push_swap binary (mandatory).

host@name:~$ make
host@name:~$ ./push_swap random_set_of_unique_integers

Building checker which checks if push_swap given instructions are correct (bonus).

host@name:~$ make bonus
host@name:~$ ./checker set_of_integers | ./checker the_same_set



About

Optimizing stack sorting with limited set of instructions.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published