From 0a9b08ce4df00e500eca5fc1971f0462488c47a4 Mon Sep 17 00:00:00 2001 From: BykovDA Date: Wed, 30 Apr 2025 16:53:00 +0300 Subject: [PATCH] =?UTF-8?q?=D0=B4=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D1=8B=20=D1=82=D0=B5=D1=81=D1=82=D1=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- histogram.cpp | 35 +++++++++++++++++++++++++++++++++++ histogram_internal.h | 8 ++++++++ unittest.cpp | 38 ++++++++++++++++++++++++++++++++++++++ 3 files changed, 81 insertions(+) create mode 100644 histogram.cpp create mode 100644 histogram_internal.h create mode 100644 unittest.cpp diff --git a/histogram.cpp b/histogram.cpp new file mode 100644 index 0000000..3fa3cf2 --- /dev/null +++ b/histogram.cpp @@ -0,0 +1,35 @@ +#include "histogram.h" +bool +find_minmax(const std::vector& numbers, double& min, double& max) { + min = numbers[0]; + max = numbers[0]; + for(double x : numbers){ + if(xmax){ + max=x; + } + } +} +std::vector +make_histogram(const std::vector& numbers,size_t bin_count){ + std::vector bins(bin_count); + double min,max; + find_minmax(numbers,min,max); + double bin_size=(max-min)/bin_count; + for(size_t i=0; i +#include +bool +find_minmax(const std::vector& numbers, double& min, double& max); + +#endif diff --git a/unittest.cpp b/unittest.cpp new file mode 100644 index 0000000..e130618 --- /dev/null +++ b/unittest.cpp @@ -0,0 +1,38 @@ +#define DOCTEST_CONFIG_NO_MULTITHREADING +#define DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN +#include "doctest.h" +#include "histogram_internal.h" + +TEST_CASE("distinct positive numbers") { + double min = 0; + double max = 0; + find_minmax({2, 2}, min, max); + CHECK(min == 2); + CHECK(max == 2); +} +TEST_CASE("empty vector"){ + double min = 0; + double max = 0; + CHECK(!find_minmax({}, min, max)); +} +TEST_CASE("vector of one elements"){ + double min = 0; + double max = 0; + find_minmax({3}, min, max); + CHECK(min == max); +} +TEST_CASE("distinct negative numbers"){ + double min = 0; + double max = 0; + find_minmax({-1, -2}, min, max); + CHECK(min == -2); + CHECK(max == -1); +} +TEST_CASE("vector of the same elements"){ + double min = 0; + double max = 0; + find_minmax({3,3,3}, min, max); + CHECK(min == 3); + CHECK(max == 3); +} +