added stalin sort
All checks were successful
Build and Deploy / build (push) Successful in 21s
Build and Deploy / deploy (push) Successful in 26s

This commit is contained in:
Maximilian Baum
2026-04-02 09:55:20 +02:00
parent f8c4e3c688
commit 9228ebbe5b
4 changed files with 75 additions and 2 deletions

View File

@@ -15,7 +15,7 @@ router.post('/', (req, res) => {
return String(a).localeCompare(String(b)); return String(a).localeCompare(String(b));
}); });
res.json({ sortedArray }); res.json({ ret: sortedArray });
}); });
module.exports = router; module.exports = router;

View File

@@ -0,0 +1,29 @@
const express = require('express');
const router = express.Router();
router.post('/', (req, res) => {
const { input } = req.body;
if (!Array.isArray(input)) {
return res.status(400).json({ error: 'Request body muss ein Feld "array" mit einem Array enthalten' });
}
const sortedArray = Array();
sortedArray.push(input[0]);
let executions = 0;
for (let i = 1; i < input.length; i++) {
if (input[i] > input[i - 1]) {
sortedArray.push(input[i]);
} else {
executions++;
}
}
res.json({
ret: sortedArray,
executions
});
});
module.exports = router;

View File

@@ -39,7 +39,7 @@
"schema": { "schema": {
"type": "object", "type": "object",
"properties": { "properties": {
"sortedArray": { "ret": {
"type": "array", "type": "array",
"items": {} "items": {}
} }
@@ -51,6 +51,48 @@
} }
} }
}, },
"/stalinSort": {
"post": {
"summary": "Sorts an array using Stalin Sort",
"requestBody": {
"required": true,
"content": {
"application/json": {
"schema": {
"type": "object",
"properties": {
"input": {
"type": "array",
"items": {}
}
}
}
}
}
},
"responses": {
"200": {
"description": "Sorted array and execution count",
"content": {
"application/json": {
"schema": {
"type": "object",
"properties": {
"ret": {
"type": "array",
"items": {}
},
"executions": {
"type": "number"
}
}
}
}
}
}
}
}
},
"/isEven": { "/isEven": {
"post": { "post": {
"summary": "Checks if number is even", "summary": "Checks if number is even",

View File

@@ -2,6 +2,7 @@ const express = require('express');
const bodyParser = require('body-parser'); const bodyParser = require('body-parser');
const path = require('path'); const path = require('path');
const sortRoute = require('./routes/api/sort'); const sortRoute = require('./routes/api/sort');
const stalinSortRoute = require('./routes/api/stalinSort');
const isEvenRoute = require('./routes/api/isEven'); const isEvenRoute = require('./routes/api/isEven');
const isOddRoute = require('./routes/api/isOdd'); const isOddRoute = require('./routes/api/isOdd');
const toStringRoute = require('./routes/api/toString'); const toStringRoute = require('./routes/api/toString');
@@ -17,6 +18,7 @@ app.use(express.static(path.join(__dirname, '../www')));
app.use(bodyParser.json()); app.use(bodyParser.json());
app.use('/api/sort', sortRoute); app.use('/api/sort', sortRoute);
app.use('/api/stalinSort', stalinSortRoute);
app.use('/api/isEven', isEvenRoute); app.use('/api/isEven', isEvenRoute);
app.use('/api/isOdd', isOddRoute); app.use('/api/isOdd', isOddRoute);
app.use('/api/toString', toStringRoute); app.use('/api/toString', toStringRoute);