Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Задача c++

Featured Replies

Това е задачата, решението и моят код по задачата ако може да ми кажете къде бъркам

 

 

#include "stdafx.h"
#include <iostream>
#include <string.h>
#include <math.h>
using namespace std;
int main()
{
 cout << "x= ";
 double x;
 cin >> x;
 if (!cin)
 {
  cout << "Error, Bad input! \n";
  return 1;
 }
 cout << "eps= ";
 double eps;
 cin >> eps;
 if (!cin)
 {
  cout << "Error, Bad input! \n";
  return 1;
 }
 if (eps <= 0)
 {
  cout << "Incorrect input! \n";
  return 1;
 }
 double x1 = 1;
 double s = 1;
 int i = 1;
 while (fabs(x1) >= eps)
 {
  x1 = pow(x, i) / i;
  s = s + x1;
  i++;
 }
 cout << "s=" << s << "\n";
 return 0;
}

D570B032-D007-44E3-BE1D-09BB1524169A.thumb.png.e5c6834de6782afa1984cad9e0f9b3a0.png419BD224-7C62-4986-93EB-5B443D411A94.thumb.png.b61c93c76891a0c21146937e5b67b8d1.png

Редактирано от Petko2002 (преглед на промените)

кода ти отговаря на редица  s=1 + x/1 +x^2/2 + x^3/3 +...   а не на S= 1 + x/1+ X^2/2! +x^3/3! плюс това е напълно излишно да ползваш pow() като можеш да минеш с умножение както е в другия код

Трябва да напишеш допълнителна функция,  факториел (и). И да делиш на резултата от тази функция.

Например

int factorial(int n)
{
    int f = 1;
    for (int i = 1; i <= n; i++)
    {
        f = f * i;
    }
    return f;
}

 

Редактирано от Реджеп Иведик (преглед на промените)

не му трябват нито pow() нито функция за факториел, хората на картинката са му я написали програмата достатъчно добре оптимизирана само с умножение и деление.

По лесно е за осмисляне. Да се научи първо да чете условията, после да му вървят програмите, и чак тогава да мисли за оптимизация. Тъй мисля аз.

Може и да си прав. 

От друга страна факториела нараства толкова бързо, че обезсмисля всички оптимизации. Колко факториела можеш да изчислиш до под два милиарда

 

  • Автор

Абе, поогледах пак задачата и отново не ми се получава, смисъл ако тръгнеш да решаваш задачата с лист и химикалка няма да се получи така... има нещо в задачата което не разбирам!!! Моля някой да обясни защото се тормозя цял ден с тая задача 

Редактирано от Petko2002 (преглед на промените)

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.