「✨」 feat: finished ex02
This commit is contained in:
60
ex02/Makefile
Normal file
60
ex02/Makefile
Normal file
@ -0,0 +1,60 @@
|
||||
# **************************************************************************** #
|
||||
# #
|
||||
# ::: :::::::: #
|
||||
# Makefile :+: :+: :+: #
|
||||
# +:+ +:+ +:+ #
|
||||
# By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ #
|
||||
# +#+#+#+#+#+ +#+ #
|
||||
# Created: 2024/10/25 16:09:27 by adjoly #+# #+# #
|
||||
# Updated: 2025/06/04 13:35:49 by adjoly ### ########.fr #
|
||||
# #
|
||||
# **************************************************************************** #
|
||||
|
||||
SHELL = bash
|
||||
|
||||
NAME = PmergeMe
|
||||
|
||||
CC = clang++
|
||||
|
||||
OBJSDIR = obj/
|
||||
|
||||
SRCS = $(shell find . -name '*.cpp')
|
||||
|
||||
OBJS = $(addprefix $(OBJSDIR), $(SRCS:.cpp=.o))
|
||||
|
||||
FLAGS = -Wall -Werror -Wextra -std=c++98 -MMD -MP
|
||||
|
||||
RED = \033[0;31m
|
||||
GREEN = \033[0;32m
|
||||
YELLOW = \033[1;33m
|
||||
PURPLE = \e[0;35m
|
||||
NC = \033[0m
|
||||
DELETE = \x1B[2K\r
|
||||
|
||||
ifeq ($(VERBOSE),true)
|
||||
FLAGS += -D VERBOSE
|
||||
endif
|
||||
|
||||
all: $(NAME)
|
||||
|
||||
$(NAME): $(OBJS)
|
||||
@$(CC) $(FLAGS) -I . $(OBJS) -o $(NAME)
|
||||
@printf "$(YELLOW)「✨」($(NAME)) Program compiled\n"
|
||||
|
||||
$(OBJSDIR)%.o: %.cpp
|
||||
@mkdir -p $(@D)
|
||||
@$(CC) $(FLAGS) -I . -c $< -o $@
|
||||
@printf "$(DELETE)$(GREEN)「🔨」($<) Object compiled\n"
|
||||
|
||||
clean:
|
||||
@rm -f $(OBJS)
|
||||
@printf "$(DELETE)$(RED)「🗑️」($(OBJS)) Object deleted\n"
|
||||
|
||||
fclean: clean
|
||||
@rm -f $(NAME)
|
||||
@rm -Rf $(OBJSDIR)
|
||||
@printf "$(RED)「🗑️」($(NAME)) Program deleted\n"
|
||||
|
||||
re: fclean all
|
||||
|
||||
.PHONY: clean fclean all re
|
BIN
ex02/PmergeMe
Executable file
BIN
ex02/PmergeMe
Executable file
Binary file not shown.
140
ex02/PmergeMe.cpp
Normal file
140
ex02/PmergeMe.cpp
Normal file
@ -0,0 +1,140 @@
|
||||
/* ************************************************************************** */
|
||||
/* */
|
||||
/* ::: :::::::: */
|
||||
/* PmergeMe.cpp :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/06/04 13:28:23 by adjoly #+# #+# */
|
||||
/* Updated: 2025/06/04 14:05:14 by adjoly ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include <PmergeMe.hpp>
|
||||
#include <algorithm>
|
||||
#include <cstddef>
|
||||
#include <ctime>
|
||||
#include <set>
|
||||
#include <sstream>
|
||||
|
||||
std::vector<int> parseInput(int argc, char **argv) {
|
||||
std::set<int> seen;
|
||||
std::vector<int> result;
|
||||
|
||||
for (int i = 1; i < argc; ++i) {
|
||||
std::istringstream iss(argv[i]);
|
||||
int value;
|
||||
if (!(iss >> value) || value < 0) {
|
||||
throw std::runtime_error("Invalid input: " + std::string(argv[i]));
|
||||
}
|
||||
if (!seen.insert(value).second) {
|
||||
throw std::runtime_error("Duplicate value: " +
|
||||
std::string(argv[i]));
|
||||
}
|
||||
result.push_back(value);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
template <typename Container> void printContainer(const Container &container) {
|
||||
for (auto it = range(container)) {
|
||||
std::cout << *it << " ";
|
||||
}
|
||||
std::cout << std::endl;
|
||||
}
|
||||
|
||||
// Measure time and run sorting for vector and deque
|
||||
void sortAndTime(std::vector<int> &vec, std::deque<int> &deq) {
|
||||
auto vecStart = std::clock();
|
||||
_fordJohnsonSort(vec);
|
||||
auto vecEnd = std::clock();
|
||||
|
||||
auto deqStart = std::clock();
|
||||
_fordJohnsonSort(deq);
|
||||
auto deqEnd = std::clock();
|
||||
|
||||
std::cout << "After: ";
|
||||
printContainer(vec);
|
||||
|
||||
double vecDuration = 1000000.0 * (vecEnd - vecStart) / CLOCKS_PER_SEC;
|
||||
double deqDuration = 1000000.0 * (deqEnd - deqStart) / CLOCKS_PER_SEC;
|
||||
|
||||
std::cout << "Time to process a range of " << vec.size()
|
||||
<< " elements with std::vector : " << vecDuration << " us"
|
||||
<< std::endl;
|
||||
|
||||
std::cout << "Time to process a range of " << deq.size()
|
||||
<< " elements with std::deque : " << deqDuration << " us"
|
||||
<< std::endl;
|
||||
}
|
||||
|
||||
std::vector<size_t> _generateJacobsthalOrder(size_t n) {
|
||||
std::vector<size_t> sequence;
|
||||
std::vector<bool> inserted(n, false);
|
||||
|
||||
// Generate the sequence
|
||||
size_t j0 = 0, j1 = 1;
|
||||
while (j1 < n) {
|
||||
sequence.push_back(j1);
|
||||
inserted[j1] = true;
|
||||
size_t next = j1 + 2 * j0;
|
||||
j0 = j1;
|
||||
j1 = next;
|
||||
}
|
||||
for (size_t i = 0; i < n; ++i) {
|
||||
if (!inserted[i])
|
||||
sequence.push_back(i);
|
||||
}
|
||||
|
||||
return sequence;
|
||||
}
|
||||
|
||||
template <typename Container> void _fordJohnsonSort(Container &container) {
|
||||
if (container.size() <= 1)
|
||||
return;
|
||||
|
||||
Container mainChain;
|
||||
Container pendingElements;
|
||||
|
||||
for (auto it = container.begin(); it != container.end();) {
|
||||
int first = *it;
|
||||
++it;
|
||||
|
||||
if (it != container.end()) {
|
||||
int second = *it;
|
||||
if (first > second) {
|
||||
mainChain.push_back(first);
|
||||
pendingElements.push_back(second);
|
||||
} else {
|
||||
mainChain.push_back(second);
|
||||
pendingElements.push_back(first);
|
||||
}
|
||||
++it;
|
||||
} else {
|
||||
mainChain.push_back(first);
|
||||
}
|
||||
}
|
||||
|
||||
_fordJohnsonSort(mainChain);
|
||||
|
||||
std::vector<size_t> order = _generateJacobsthalOrder(pendingElements.size());
|
||||
for (size_t i = 0; i < order.size(); ++i) {
|
||||
_binaryInsert(mainChain, pendingElements[order[i]]);
|
||||
}
|
||||
container = mainChain;
|
||||
}
|
||||
|
||||
template <typename Container> void _binaryInsert(Container &sorted, int value) {
|
||||
typename Container::iterator itL = sorted.begin();
|
||||
typename Container::iterator itH = sorted.end();
|
||||
|
||||
while (itL < itH) {
|
||||
typename Container::iterator itMid = itL + (itH - itL) / 2;
|
||||
if (*itMid < value)
|
||||
itL = itMid + 1;
|
||||
else
|
||||
itH = itMid;
|
||||
}
|
||||
|
||||
sorted.insert(itL, value);
|
||||
}
|
36
ex02/PmergeMe.hpp
Normal file
36
ex02/PmergeMe.hpp
Normal file
@ -0,0 +1,36 @@
|
||||
/* ************************************************************************** */
|
||||
/* */
|
||||
/* ::: :::::::: */
|
||||
/* PmergeMe.hpp :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/06/04 13:27:20 by adjoly #+# #+# */
|
||||
/* Updated: 2025/06/04 13:45:07 by adjoly ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <deque>
|
||||
#include <iostream>
|
||||
#include <stdexcept>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
#define auto __auto_type
|
||||
|
||||
#define range(x) \
|
||||
x.begin(); \
|
||||
it != x.end(); \
|
||||
it++
|
||||
|
||||
std::vector<int> parseInput(int argc, char **argv);
|
||||
|
||||
template <typename Container> void printContainer(const Container &container);
|
||||
|
||||
void sortAndTime(std::vector<int> &vec, std::deque<int> &deq);
|
||||
|
||||
template <typename Container> void _fordJohnsonSort(Container &container);
|
||||
|
||||
template <typename Container> void _binaryInsert(Container &sorted, int value);
|
34
ex02/main.cpp
Normal file
34
ex02/main.cpp
Normal file
@ -0,0 +1,34 @@
|
||||
/* ************************************************************************** */
|
||||
/* */
|
||||
/* ::: :::::::: */
|
||||
/* main.cpp :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/06/04 13:26:50 by adjoly #+# #+# */
|
||||
/* Updated: 2025/06/04 13:44:29 by adjoly ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include <PmergeMe.hpp>
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
if (argc < 2) {
|
||||
std::cerr << "Error: No input provided" << std::endl;
|
||||
return 1;
|
||||
}
|
||||
|
||||
try {
|
||||
std::vector<int> inputVector = parseInput(argc, argv);
|
||||
std::deque<int> inputDeque(inputVector.begin(), inputVector.end());
|
||||
|
||||
std::cout << "Before: ";
|
||||
printContainer(inputVector);
|
||||
|
||||
sortAndTime(inputVector, inputDeque);
|
||||
|
||||
} catch (const std::exception &e) {
|
||||
std::cerr << "Error: " << e.what() << std::endl;
|
||||
return 1;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user