From d9e8ccb3b2dfbfbb5c506ce88a72e46b4fbb07fb Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 10 Jul 2023 14:14:15 +0100 Subject: (bsearch)+algorithm implementation Reads lines from "bsearch.txt", asks user for a number then binary searches that number in the input data from "bsearch.txt". --- bsearch.cpp | 57 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 bsearch.cpp (limited to 'bsearch.cpp') diff --git a/bsearch.cpp b/bsearch.cpp new file mode 100644 index 0000000..6172b15 --- /dev/null +++ b/bsearch.cpp @@ -0,0 +1,57 @@ +/* bsearch.cpp + * Created: 2023-07-10 + * Author: Aryadev Chavali + */ + +#include +#include +#include +#include +#include +#include + +using std::cin; +using std::cout; +using std::endl; +using std::ostream; +using std::string; +using std::vector; + +vector arr; + +ostream &print_arr(ostream &os) +{ + os << "["; + for (size_t i = 0; i < arr.size(); ++i) + os << arr[i] << (i == arr.size() - 1 ? "" : ","); + return os << "]"; +} + +int bsearch(int n, int l = 0, int u = arr.size() - 1) +{ + int midpoint = ((u + l) / 2); + if (l >= u || u <= 0) + return -1; + int val = arr[midpoint]; + if (val == n) + return midpoint; + else if (val > n) + return bsearch(n, l, midpoint - 1); + else + return bsearch(n, midpoint + 1, u); +} + +int main(void) +{ + std::ifstream input("bsearch.txt"); + string line; + while (std::getline(input, line)) + arr.push_back(std::stoi(line)); + std::sort(std::begin(arr), std::end(arr)); + string inp; + cout << "Enter number to search: "; + cin >> inp; + int to_search = std::stoi(inp); + cout << bsearch(to_search) << endl; + return 0; +} -- cgit v1.2.3-13-gbd6f