Skip to content

Commit c661604

Browse files
author
Raghav Dua
authored
Merge pull request algorithm-visualizer#215 from AdhityaRamadhanus/pancake-sort
add pancake sort
2 parents 8fcbad0 + bfc8eef commit c661604

File tree

4 files changed

+52
-1
lines changed

4 files changed

+52
-1
lines changed

algorithm/category.json

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -85,7 +85,8 @@
8585
"quick": "Quicksort",
8686
"radix": "Radix Sort",
8787
"selection": "Selection Sort",
88-
"shell": "Shellsort"
88+
"shell": "Shellsort",
89+
"pancake": "Pancake Sort"
8990
},
9091
"name": "Sorting"
9192
},
Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
logger._print('original array = [' + D.join(', ') + ']');
2+
var N = D.length;
3+
function flip (start) {
4+
tracer._select(start, N)._wait();
5+
var idx = 0;
6+
for (var i=start;i<(start+N)/2;i++) {
7+
tracer._select(i)._wait();
8+
var temp = D[i];
9+
D[i] = D[N-idx-1];
10+
D[N-idx-1] = temp;
11+
idx++;
12+
tracer._notify(i, D[i])._notify(N-idx, D[N-idx])._wait();
13+
tracer._denotify(i)._denotify(N-idx);
14+
tracer._deselect(i);
15+
}
16+
tracer._deselect(start, N);
17+
}
18+
for (var i=0;i<N-1;i++) {
19+
logger._print('round ' + (i+1));
20+
var currArr = D.slice(i, N);
21+
var currMax = currArr.reduce((prev, curr, idx) => {
22+
return (curr > prev.val) ? { idx: idx, val: curr} : prev;
23+
}, {idx: 0, val: currArr[0]});
24+
if (currMax.idx !== i) {
25+
logger._print('flip at ' + (currMax.idx+i) + ' (step 1)');
26+
flip(currMax.idx+i, N);
27+
logger._print('flip at ' + (i) + ' (step 2)');
28+
flip(i, N);
29+
}
30+
}
31+
logger._print('sorted array = [' + D.join(', ') + ']');
Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
var chart = new ChartTracer();
2+
var tracer = new Array1DTracer().attach(chart);
3+
var logger = new LogTracer();
4+
var D = Array1D.random(10);
5+
tracer._setData(D);

algorithm/sorting/pancake/desc.json

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
{
2+
"Pancake Sort": "Pancake Sort,inspired from sorting a stack of pancake using spatula, is a simple sorting algorithm that only have 1 operation called flip. </br> flip (i) : Reverse array from i to N where N is length of array ",
3+
"Complexity": {
4+
"time": "worst $O(n^2)$",
5+
"space": "worst $O(1)$ auxiliary"
6+
},
7+
"References": [
8+
"<a href='https://en.wikipedia.org/wiki/Pancake_sorting'>Wikipedia</a>",
9+
"<a href='http://www.geeksforgeeks.org/pancake-sorting/'>Geeksforgeeks</a>"
10+
],
11+
"files": {
12+
"basic": "Pancake sort"
13+
}
14+
}

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy