code: выполненный код

master
KonovalovaAA 2 лет назад
Родитель 487e87fa26
Сommit 89f5920b56

@ -13,7 +13,12 @@
<Option compiler="gcc" /> <Option compiler="gcc" />
<Compiler> <Compiler>
<Add option="-g" /> <Add option="-g" />
<Add directory="curl/include" />
</Compiler> </Compiler>
<Linker>
<Add library="libcurl.dll.a" />
<Add directory="curl/lib" />
</Linker>
</Target> </Target>
<Target title="Release"> <Target title="Release">
<Option output="bin/Release/1" prefix_auto="1" extension_auto="1" /> <Option output="bin/Release/1" prefix_auto="1" extension_auto="1" />

@ -20,7 +20,7 @@
<iostream> <iostream>
<vector> <vector>
1684762502 source:c:\users\79156\desktop\3\main.cpp 1684764299 source:c:\users\79156\desktop\3\main.cpp
<iostream> <iostream>
<vector> <vector>
<cmath> <cmath>
@ -28,6 +28,8 @@
"histogram.h" "histogram.h"
"svg.h" "svg.h"
<curl/curl.h> <curl/curl.h>
<sstream>
<string>
1681131908 c:\users\79156\desktop\3\histogram.h 1681131908 c:\users\79156\desktop\3\histogram.h
<vector> <vector>

@ -1,77 +1,89 @@
#include <iostream> #include <iostream>
#include <vector> #include <vector>
#include <cmath> #include <conio.h>
#include <windows.h>
#include "histogram.h" #include "histogram.h"
#include "text.h"
#include "svg.h" #include "svg.h"
#include <curl/curl.h> #include <curl/curl.h>
#include <sstream>
#include <string>
using namespace std; using namespace std;
struct Input struct Input
{ {
vector<double> numbers; vector<double> numbers;
size_t bin_count{}; size_t bin_count{};
}; };
Input Input
input_data(istream& tin, bool prompt) input_data(istream& in, bool promt)
{ {
size_t number_count; size_t number_count;
if(prompt) if (promt)
cerr << "Enter number_count "; {
cerr << "Enter number count: ";
tin >> number_count; }
in >> number_count;
vector<double> numbers(number_count);
Input in;
in.numbers.resize(number_count);
if(prompt)
cerr << "Enter numbers ";
Input it;
it.numbers.resize(number_count);
for (size_t i = 0; i < number_count; i++) for (size_t i = 0; i < number_count; i++)
{ {
cin >> in.numbers[i]; in >> it.numbers[i];
} }
if (promt)
size_t bin_count; {
cerr << "Enter bin count: ";
if(prompt) }
cerr << "Enter bin_count "; in>> it.bin_count;
return it;
tin >> in.bin_count;
return in;
} }
size_t write_data(void* items, size_t item_size, size_t item_count, void* ctx)
{
size_t data_size = item_size * item_count;
stringstream* buffer = reinterpret_cast<stringstream*>(ctx);
buffer->write(reinterpret_cast<const char*>(items), data_size);
return data_size;
}
Input
download(const string& address)
int main(int argc, char* argv[])
{ {
if(argc > 1){ stringstream buffer;
CURL *curl = curl_easy_init(); CURL *curl = curl_easy_init();
if(curl) if(curl)
{ {
CURLcode res; CURLcode res;
curl_easy_setopt(curl, CURLOPT_URL, "https://example.com"); curl_easy_setopt(curl, CURLOPT_URL, address.c_str());
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_data);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &buffer);
res = curl_easy_perform(curl); res = curl_easy_perform(curl);
if(res != CURLE_OK){ if (res != CURLE_OK)
fprintf(stderr, "curl_easy_perform() failed: %s\n", {
curl_easy_strerror(res)); fprintf(stderr, "curl_easy_perform() failed: %s\n",curl_easy_strerror(res));
exit(1);} exit(1);
}
curl_easy_cleanup(curl); curl_easy_cleanup(curl);
}
return input_data(buffer, false);
} }
return 0;
int main(int argc, char* argv[])
{
Input input;
if (argc > 1)
{
input = download(argv[1]);
}
else
{
input = input_data(cin, true);
} }
curl_global_init(CURL_GLOBAL_ALL);
auto in = input_data(cin, false); const auto bins = make_histogram(input.numbers, input.bin_count);
auto bins = make_histogram(in.numbers, in.bin_count);
show_histogram_svg(bins); show_histogram_svg(bins);
return 0;
} }

Загрузка…
Отмена
Сохранить