Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 23.09.2013
Сообщений: 13

Написать реализацию заданной функции

22.10.2013, 21:44. Показов 940. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
как записать на С++ Builder такое
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.10.2013, 21:44
Ответы с готовыми решениями:

Возможно ли посмотреть реализацию библиотечной функции?
Здравствуйте. Возможно ли просмотреть реализацию библиотечной функции,если да,то как? с++(MSVS 2013);

Как по заданной блок-схеме написать реализацию?
Ребят первый раз в жизни пишу программу. Надо по заданой блок-схеме написать код. У меня проблема с циклом не могу понять что не так....

Написать реализацию перегрузки функции
Написать реализацию перегрузки функции int func(int * arr, int lenght) int func(double * arr, int length) Функция func возвращает...

4
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33400 / 21510 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
22.10.2013, 22:30
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
    const float eps = 0.0001;
    float x = 0.4, f, s = 0;
    float xval = x;
    int i = 1;
    do
    {
        i += 1;
        s += (f = i * (i + 1) * (i + 2) * xval);
        xval *= x;
    }
    while(f > eps);
    s = s / 6.0 + 1;
 
    ShowMessage(FloatToStr(s) + " vs " + FloatToStr(1 / Power(1 - x, 4))); // для сравнения
2
place status here
 Аватар для gunslinger
3190 / 2227 / 640
Регистрация: 20.07.2013
Сообщений: 6,023
23.10.2013, 00:27
А я так сделал (вызывала сомнение сходимость разложения функции рядом с границами интервала допустимых значений х, но "добавление точки" в (n+1) после 1 "решило проблему").
У тебя, UI, при значениях |x|, близких к 1 (особенно для x->+1), результаты расходятся достаточно сильно.
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
double memb(double x, long int n)
{
  return (n+1.)*(n+2)*(n+3)*Power(x,n)/6;  // "волшебная точка" после 1
}
//---------------------------------------------------------------------------
void res(double x, double dif)
{
  double sum = 1.0, temp;
  long int n = 1;
  temp = memb(x, n);
  if (fabs(x) < 1)
  {
    while (fabs(temp) >= dif)
    {
      sum += temp;
      n++;
      temp = memb(x, n);
    }
    MessageBox(Application->Handle, ("x = " + FloatToStr(x) + "\ndif = " + FloatToStr(dif) + "\nf(x) = " + FloatToStr(RoundTo(sum, -6)))\
    .c_str(), "Результат", MB_ICONASTERISK+MB_TOPMOST);
//  ShowMessage(RoundTo(Power(1-x,-4), -6));  // для сравнения
  }
  else
    MessageBox(Application->Handle, "Должно выполняться условие: |x| < 1", "Неверное значение х", MB_ICONASTERISK+MB_TOPMOST);
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
  res(0.5, 0.000001);
}

Не по теме:

P.S.: посмотрите задачу Спички, там точно мозги начнут шевелиться :)

Изображения
   
1
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33400 / 21510 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
23.10.2013, 00:57
Цитата Сообщение от gunslier Посмотреть сообщение
А я так сделал
И чем гордишься? Тем, что используешь библиотечные функции? Или тем, что дублируешь код? Или тем, что на каждой итерации делишь на 6 вместо того, чтобы вынести это за цикл?

Добавлю я в 8 строку точку после 1 или после 2, и будут одинаковые результаты при любых значениях Х... Или, что еще лучше, просто перепишу ее вот так, безо всякой "магии":
C++
1
        s += (f = xval * i * (i + 1) * (i + 2));
1
place status here
 Аватар для gunslinger
3190 / 2227 / 640
Регистрация: 20.07.2013
Сообщений: 6,023
23.10.2013, 02:13
Да ничем я не горжусь. Предлагаешь вместо возведения в (целочисленную) степень перемножать в цикле?
Дублированием не занимаюсь, твой код увидел лишь где-то через час после его появления, что подтолкнуло на единственное исправление ошибки в приведении типов.
Оптимизация кода - небольшой бонус для ТС. К тому же сходимость ряда правильней проверять по полному значению члена ряда, хотя в данном случае из-за уменьшающего коэффициента твое сравнение погрешности лучше (при должном значении переменной).
Так как моя основная работа давно уже не связана с программированием, решение той или иной задачи здесь маленькая победа для меня (не более) и поддержание серого вещества в форме.
Поэтому не испытываю потребность кому-либо что-то доказывать или показывать, что я лучше.
Не надо воспринимать замеченные ошибки близко к сердцу (я стараюсь делать это не часто и как можно нейтральнее), идеальных людей в природе не встречал.
Спасибо за внимание.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.10.2013, 02:13
Помогаю со студенческими работами здесь

Написать реализацию функции Pos
Нужно написать свою функцию POS. Без использования встроенных строковых функций(кроме length()). Спасибо.

Написать собственную реализацию функции copy.
Написать собственную реализацию функции copy.Сравнить результаты работы стандартного и своего вариантов процедуры для произвольной строки. ...

Как написать собственную рекурсивную реализацию функции last?
как написать собственную рекурсивную реализацию функции last ?

Написать собственную реализацию стандартной функции strstr
Написать собственную реализацию стандартной функции strstr. предназначена для поиска строки strCharSet в строке string. Возвращается...

Написать собственную реализацию функции strcmp() согласно условию
Постановка задачи такова,нужно переписать strcmp ,чтобы где не важен был бы регистр букв и использовалось лексикографическое сравнение.В...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
1С: Программный отбор элементов справочника Номенклатура по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор под наименованию группы (на. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника Сотрудники по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru