Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
 Аватар для Mesteriis
599 / 237 / 69
Регистрация: 08.08.2015
Сообщений: 1,637

Разработка метода, распределяющего натуральное число на части, согласно графику y = sin x

21.01.2016, 23:33. Показов 1162. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброе время суток!


Ребят "Ай ниид хелп!". прям в ступоре. Вопрос больше лежит в области математики нежели программирования, но все же сюда! Смотрите, прям вот на пальцах потому что если напишу по умному "нечерта" не пойму сам!

Необходимо разработать метод который будет принимать в себя 3 параметра (количество точек на "синусоиде"(об этом позже), сумма всех точек на синусоиде, точку входа в график синусоиды.

И так по порядку, сразу на примере, а то не знаю как проще объяснить:
- Представьте график синусоиды, и возьмите его от значения x = 0 до x = 2pi. То есть как говорил наш школьный математик законченный синус.

Передаем:
12 как колво точек
100 как сумму всех чисел
0 как точку входа.

На выходе должны получить 12 положительный чисел сумма которых будет составлять 100, но они будут разбиты таким образом что на позиции графика pi/2 будет максимальное, а на позиции (3*pi)/2 минимальное

Пример выхода :

2.332 , 3.25 , 3.95 4.20 , 6.45 , 8.333,13.415 , 14.34 , 12.715 , 12.465 ,10.21 , 8.333


PS Если это какая то задача с именем, то сори не знаю такой!

Добавлено через 10 минут
Цитата Сообщение от Mesteriis Посмотреть сообщение
pi/2 будет максимальное, а на позиции (3*pi)/2
Згнался не тот пример взял, начало 0 конец 2pi
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.01.2016, 23:33
Ответы с готовыми решениями:

Дано натуральное число N. Вычислить S=sin x+ sin sinx +...+sin sin....sin x
Дано натуральное число N. Вычислить S (составить программу с использованием операторов While и Repeat) S=sin x+ sin sinx +...+sin...

Дано целое число N (>0). Найти сумму Sin(x) + Sin(2x) + … + Sin(Nx)
А можно сделать чтоб одна строка все суммировала, или write(тут код). условие вв

Для заданного числа x распечатать числовую последовательность: sin(x), sin(sin(x), sin(sin(sin(x), …
var x,z:integer; y:real; begin readln(x); y:=abs(sin(x)); while y>0.01 do begin y:=abs(sin(x)) ; // write(y); ...

5
Полярный
 Аватар для dimcoder
476 / 448 / 158
Регистрация: 11.09.2011
Сообщений: 1,156
22.01.2016, 00:47
Mesteriis, прочитал. Не понял. Еще раз прочитал. Еще раз не понял. Есть точная формулировка задачи?
Что представляют эти 12 чисел?
Цитата Сообщение от Mesteriis Посмотреть сообщение
Згнался не тот пример взял, начало 0 конец 2pi
не [0.5pi, 1.5pi]?
0
 Аватар для Mesteriis
599 / 237 / 69
Регистрация: 08.08.2015
Сообщений: 1,637
22.01.2016, 14:11  [ТС]
Цитата Сообщение от dimcoder Посмотреть сообщение
Есть точная формулировка задачи?
Увы нет, я знаю я не селен в описании, как прям заказчик)))
Цитата Сообщение от dimcoder Посмотреть сообщение
Что представляют эти 12 чисел?
это количество членов на которые необходимо разбить число.

И так несколько примеров что бы было понятно что требуется.
1й.
график 1. точка входа "0".
число которое надо разбить 100.
число членов 4.
разбиваем график на 4 отрезка по оси х. Это на отметке х=0; 1.5; 3.2; 4.7 ; 6.3

соответственно минимальное значение элемента будет на 4,7 а максимальное на 1,5. и получаем 25; 45; 5;25.

График 2. точка входа 1,6
число которое надо разбить 100.
число членов 12.
тоже самое разбиваем график на 12 частей и пропорционально разбираем число. максимальные значения в начале и в конце ряда, а минимальное посередине!
Миниатюры
Разработка метода, распределяющего натуральное число на части, согласно графику y = sin x   Разработка метода, распределяющего натуральное число на части, согласно графику y = sin x  
0
Полярный
 Аватар для dimcoder
476 / 448 / 158
Регистрация: 11.09.2011
Сообщений: 1,156
22.01.2016, 23:22
Лучший ответ Сообщение было отмечено Mesteriis как решение

Решение

Mesteriis,
C++ Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <iostream>
#include <vector>
#include <cmath>
#include <iomanip>
#include <algorithm>
 
void print(std::vector<double> vector);
 
int main()
{
    const double    PI      = 3.14159265359;
    const int       N       = 12;  //4
    const int       Q       = 100;
 
    const double    OFFSET  = 0;
 
    const double    STEP            = (1.0 / N) * 2 * PI;
    const double    AVERAGE_VALUE   = (double)Q / N;
    const double    SCATTER         = 6; //20
 
    std::vector<double> x_coordinates, y_values;
 
    for (int i = 0; i < N; i++)
        x_coordinates.push_back(i * STEP + OFFSET);
    //print(x_coordinates);
 
    for (auto& x: x_coordinates)
        y_values.push_back(AVERAGE_VALUE + sin(x) * SCATTER);
    print(y_values);
 
    double init = 0;
    for (auto& y: y_values)
        init += y;
    std::cout << init << std::endl;
 
    return 0;
}
 
void print(std::vector<double> v)
{
    std::cout.precision(4); 
    for (auto& i: v)
        std::cout << std::left << std::setw(5) << i << ' ';
    std::cout << std::endl << std::endl;
}
Пока не очень понятно как выбирать SCATTER (разброс). Для задачи с четыремя числами 25, 5, 45, 25, можно выбрать значение 20. Как получить прямо такие же значения как из первого поста пока не очень ясно, но SCATTER тут должен быть 6.
Если что-то не понятно, спрашивайте.
Миниатюры
Разработка метода, распределяющего натуральное число на части, согласно графику y = sin x  
1
 Аватар для Mesteriis
599 / 237 / 69
Регистрация: 08.08.2015
Сообщений: 1,637
23.01.2016, 16:50  [ТС]
dimcoder, ну впринцепе понятно, спсибо, теперь буду думать как в автомате расчитывать разброс для разных значений
0
Полярный
 Аватар для dimcoder
476 / 448 / 158
Регистрация: 11.09.2011
Сообщений: 1,156
23.01.2016, 23:03
Цитата Сообщение от Mesteriis Посмотреть сообщение
разброс для разных значений
Если зависимость линейная, то исходя из двух точек (8.3333, 6) и (25, 20) (где x это AVERAGE_VALUE, y - SCATTER), то можно вывести уравнение
Code Скопировано
1
2
3
SCATTER = 0.84 * AVERAGE_VALUE - 1;
AVERAGE_VALUE = 8.333 ---> SCATTER = 6
AVERAGE_VALUE = 25 ---> SCATTER = 20
Думаю это все что можно сказать исходя из двух примеров.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.01.2016, 23:03
Помогаю со студенческими работами здесь

Дано натуральное число n. Выяснить, сколько положительных элементов содержит матрица {aij} i, j = 1, …, n, если aij = sin(i+j/2)
Дано натуральное число n. Выяснить, сколько положительных элементов содержит матрица {aij} i, j = 1, …, n, если aij = sin(i+j/2).

Вычислить первое из чисел sin(x), sin(sin(x)), sin(sin(sin(x))), ... , меньшее по модулю 10^-4
1)Вычислить y - первое из чисел sinx, sin sinx,sin sin sinx,..., меньшее по модулю 10^-4 Заранее огромное спасибо!

Вычислить у - первое из чисел sin х, sin sin x, sin sin sin x, ., меньшее по модулю 10-4
Вычислить у - первое из чисел sin х, sin sin x, sin sin sin x, ..., меньшее по модулю 10-4 Видел код на паскале, перенес его на Java. Не...

Нарисовать касательную к графику y=sin(x)
нужно нарисовать касательную к sin(x) вот код к графику sin(x) for(x=-50;x&lt;=50;x++) {y=sin(x/10); ...

Для заданных n и x посчитать выражение s=sin x+sin sin x+...+sin sin sin...sin x
Для заданных n и x посчитать выражение s=sin x+sin sin x+...+sin sin sin...sin x (n раз).


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
Метод с двумя буферами (или double buffering) или ping-pong buffering
Hrethgir 02.04.2025
Из ответов LM модели. Метод, который предполагает использование двух массивов для хранения промежуточных результатов сложения векторов, обычно применяется в сценариях, где необходимо минимизировать. . .
На любовном киберфронте
Alexander-7 01.04.2025
Недавно на одном малоизвестном сайте знакомств мною заинтересовалась девушка: «Текст немного странный. Но, судя по адресу почты, иностранка», – подумал я. Поколебавшись пару суток, я ответил ей:. . .
Как работает Node.js изнутри
run.dev 29.03.2025
Node. js изменил подход к разработке веб-приложений, позволив использовать JavaScript не только на стороне клиента, но и на сервере. Созданный в 2009 году Райаном Далем, этот открытый,. . .
Моки в Python: Mock Object Library
py-thonny 29.03.2025
Тестирование кода требует особого подхода, когда речь идёт о компонентах, взаимодействующих с внешним миром. Мы часто сталкиваемся с непредсказуемостью HTTP-запросов, чтением данных из базы или. . .
JavaScript: Управление памятью и улучшение производительности
run.dev 29.03.2025
В отличие от низкоуровневых языков программирования, JavaScript не требует ручного выделения и освобождения памяти. Здесь работает автоматический сборщик мусора, который определяет, какие объекты. . .
Мультитенантная архитектура со SpringBoot и PostgreSQL
ArchitectMsa 29.03.2025
SaaS-приложения редко обслуживают одного клиента и обычно они должны поддерживать множество организаций, каждая из которых работает в своём изолированном пространстве. Мультитенантная архитектура. . .
std::span в C++: Производительность и лучшие практики
NullReferenced 28.03.2025
std::span — одно из самых недооценённых нововведений стандарта C++20, которое радикально меняет подход к работе с непрерывными последовательностями данных. По сути, это невладеющее представление. . .
Многопоточность в C#: Threadpool
UnmanagedCoder 28.03.2025
Пул потоков в C# — это коллекция заранее созданных и готовых к использованию потоков, которые находятся в распоряжении приложения. Вместо того чтобы создавать и уничтожать потоки для каждой небольшой. . .
Вопросы на собеседованиях по микросервисам
ArchitectMsa 27.03.2025
Работодатели ищут не просто разработчиков, знающих базовые концепции, а специалистов, разбирающихся в тонкостях масштабирования, отказоустойчивости и производительности. Сейчас на первый план выходят. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер