4 / 4 / 0
Регистрация: 12.12.2009
Сообщений: 29

Написать функцию возведения вещественного числа в целую степень без math.h

13.12.2009, 17:58. Показов 6421. Ответов 9
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
необходимо написать программу в которой используется ф-я возведения некоторого вещественного числа в некую целую степень.
Условия выхода-возведение в 1 степень, но и при этом необходимо вычислить...
include <math.h> использовать запрещено...
подскажите с программой, вот я пытался написать код, но не совсем получается:
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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
double N_O (double, int)
void main()
{
clrscr ();
double y,x;
int n;
while (1)
{
printf ("vvedite osnovanie x= \n");
scanf ("%lf ",&x);
printf ("vvedite stepen n= \n");
scanf ("%d ",&n);
if (n==1) {printf ("y=%lf \n",y);break;}
y=N_O (R);
printf ("y= %lf \n",y);
}
}
 
double N_O (double b, int c) //ф-ю не могу написать
{
double P;
помогите чем-нибудь... заранее благодарен...
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.12.2009, 17:58
Ответы с готовыми решениями:

Написать эффективную функцию для возведения числа в положительную целую степень
ошибок не выводит, но единственное ругается на int с подусловием в 25 строке, помогите плз исправить данный недочет условие: Написать...

Написать функцию возведения действительного числа в целую степень
Описать функцию Power2(A, N) вещественного типа, находящую величину AN (A — вещественный, N — целый параметр) по следующим формулам: A0 =...

Рекурсивная функция возведения вещественного числа в целую степень
Решите задачку, плиз ((( Описать рекурсивную функцию pow(x, n) от вещественного x (x &lt;&gt; 0) и целого n, которая вычисляет величину...

9
4 / 4 / 0
Регистрация: 12.12.2009
Сообщений: 29
13.12.2009, 20:10  [ТС]
пересмотрел задачу, сделал по другому, но всё равно не получается...
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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
double N_O (double, int)
void main()
{
clrscr ();
double y=1.0,x;
int n;
do {printf ("vvedite osnovanie x= \n");
scanf ("%lf ",&x);
printf ("vvedite stepen n= \n");
scanf ("%d ",&n);  
 if (n=0) printf ("y=1"); 
else y=N_O (x,y);
printf ("y=%lf \n",y);  
}while (n!=1) printf ("y=%lf",x); break; 
}
 
double N_O (double b, int c) 
{
double P;
if (n<0) b=1/b; P*=b;
for (i=1;i<c;i++)
P*=c;
return P;
}
0
 Аватар для Harlequin
42 / 42 / 7
Регистрация: 08.11.2009
Сообщений: 167
13.12.2009, 20:22
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

не так сделал

правильно так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
double N_O (double b, int c)
{
    if(c==0)
        return 1;
 
    double Result = 1;
    for (int i=0; i < abs(c); i++)
        Result *= P;
 
    if(c<0)
        Result = 1 / Result;
 
    return Result;
}
1
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
13.12.2009, 20:30
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
#include <iostream>
 
using namespace std;
 
double BinPow(double a, int n)
{
    double res = 1.0;
    while (n)    
    {
        if (n&1)    
        {
            res *= a;
            --n;
        }
        else
        {
            a *= a;
            n >>= 1;
        }
    }
    return res;
}
 
int main()
{
    double a;
    int n;
    cin >> a >> n;
    cout << (BinPow(a,n)) << endl;
    system("pause");
    return 0;
}
- бинарное возведение в степень (закодил за 1:38 сек
на чистый сишник сам переведешь..
1
4 / 4 / 0
Регистрация: 12.12.2009
Сообщений: 29
13.12.2009, 21:10  [ТС]
написал программу:
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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
double N_O (double, int);
void main()
{
clrscr ();
double y=1,x;
int n;
do {printf ("vvedite osnovanie x=\n");
scanf ("%lf ",&x);
printf ("vvedite stepen n= \n");
scanf ("%d ",&n);
if (n!=0) y=N_O (x,n);
printf ("%lf v stepeni %d= %lf \n",x,n,y);
printf ("\n");
getch();
} while (n!=1);
}
double N_O (double b, int c)
{
if (c==0)
return 1;
double result=1;
for (int i=0; i<abs(c);i++)
result*=b;
if (c<0)
result=1/result;
return result;
}
она считает, но когда ввожу "х" надо ввести число 2 раза, затем просит ввести степень, но считает за степень не это число , а то которое вводили второй раз в основание, а эту степень берет для следующего основания... подскажите что делать...
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
13.12.2009, 21:14
а чем тебе бинарник не нрав.? используй форматирование, пожалуйста, ничего не понятно..
1
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
13.12.2009, 21:18
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
double N_O (double, int);
void main()
{
clrscr ();
double y=1,x;
int n;
do {printf ("vvedite osnovanie x=\n");
scanf ("%lf",&x);
printf ("vvedite stepen n= \n");
scanf ("%d",&n);
if (n!=0) y=N_O (x,n);
printf ("%lf v stepeni %d= %lf \n",x,n,y);
printf ("\n");
getch();
} while (n!=1);
}
double N_O (double b, int c)
{
if (c==0)
return 1;
double result=1;
for (int i=0; i<abs(c);i++)
result*=b;
if (c<0)
result=1/result;
return result;
}
1
4 / 4 / 0
Регистрация: 12.12.2009
Сообщений: 29
13.12.2009, 21:29  [ТС]
извени, а чем отличается твой код от моего? может я не заметил (мозги уже кипят)
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
13.12.2009, 21:34
Вот моя строка:
C
1
scanf ("%lf",&x);
Сравни со своей
1
4 / 4 / 0
Регистрация: 12.12.2009
Сообщений: 29
13.12.2009, 21:38  [ТС]
спасибо большое всем кто помог
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.12.2009, 21:38
Помогаю со студенческими работами здесь

Написать программу возведения целого числа в целую степень, без использования стандартных функций
Здравствуйте!!! Помогите , пожалуйста написать программу с помощью цикла. написать программу возведения целого числа в целую степень,...

Составить программу вычисления, используя процедуру возведения вещественного числа в целую степень
Составить программу вычисления, используя процедуру возведения вещественного числа в целую степень. Procedure Step (n: integer; x:...

Написать функцию возведения в целую степень
Написать функцию возведения в целую степень без POW

Реализовать функцию возведения целого числа в целую степень
1. Реализовать функцию возведения целого числа в целую степень.

Написать подпрограмму возведения числа в целую степень
Помогите написать программу &quot;Написать подпрограмму возведения числа в целую степень. Проверить её работу на данных: 2^10,3&quot;5^-1,...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

Новые блоги и статьи
Анализ и линтинг кода JavaScript: ESLint, Prettier и JSHint
run.dev 26.04.2025
JavaScript прошёл долгий путь от простого языка для анимации веб-страниц до основы современной веб-разработки. С ростом сложности приложений, увеличением кодовых баз и масштабированием команд. . .
Паттерны в Python: Singleton, Factory и Observer
py-thonny 26.04.2025
Паттерны проектирования — это проверенные временем решения типовых проблем разработки программного обеспечения. Их история берёт начало с книги "Приёмы объектно-ориентированного проектирования. . . .
Исключения в C#: Stack Overflow, Access Violation и Out of memory
stackOverflow 26.04.2025
Исключения в C# — это не только механизм оповещения о проблемах, а целое искусство управления потоком выполнения программы в экстремальных ситуациях. Обычное исключение, например,. . .
Логирование в C# ASP.NET Core с помощью Serilog, ElasticSearch, Kibana
stackOverflow 25.04.2025
Помните те времена, когда для анализа проблемы приходилось подключаться к серверу, искать нужный лог-файл среди десятков других и вручную фильтровать тысячи строк в поисках ошибки? К счастью, эти дни. . .
Структура "железный OnKeyUp" вместо антидребезга. Полностью асинхронный счётчик.
Hrethgir 25.04.2025
Программа для симуляции схемы - Logisim Evolution В общем какое-то время отвлёкся, так было надо, теперь когда запилю это на verilog и FPGA , досоставлю заявку в ФИПС на полезную модель - не готов. . .
Автоматизация Amazon Web Services (AWS) с Boto3 в Python
py-thonny 25.04.2025
Облачные вычисления стали неотъемлемой частью современной ИТ-инфраструктуры, а Amazon Web Services (AWS) занимает лидирующие позиции среди провайдеров облачных услуг. Управление многочисленными. . .
Apache Kafka vs RabbitMQ в микросервисной архитектуре
ArchitectMsa 25.04.2025
Современная разработка ПО всё чаще склоняется к микросервисной архитектуре — подходу, при котором приложение разбивается на множество небольших, автономных сервисов. В этой распределённой среде. . .
Параллельное программирование с OpenMP в C++
NullReferenced 24.04.2025
Параллельное программирование — подход к созданию программ, когда одна задача разбивается на несколько подзадач, которые могут выполняться одновременно. Оно стало необходимым навыком для. . .
Цепочки методов в C# с Fluent API
UnmanagedCoder 24.04.2025
Современное программирование — это не только решение функциональных задач, но и создание кода, который удобно поддерживать, расширять и читать. Цепочки методов и Fluent-синтаксис в C# стали мощным. . .
Мульти-тенантные БД с PostgreSQL Row Security
Codd 23.04.2025
Современные облачные сервисы и бизнес-приложения всё чаще обслуживают множество клиентов в рамках единой программной инфраструктуры. Эта архитектурная модель, известная как мульти-тенантность, стала. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru