2 / 2 / 0
Регистрация: 07.06.2016
Сообщений: 63
1

Альтернатива pow для int

23.06.2016, 19:14. Показов 8131. Ответов 18
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем привет. Написал код для определения суммы элементов целочисленного массива, типа a1+2a^2+3a^3+...+8a^8.
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 <iostream>
#include <ctime>
#include <cmath>
 
using namespace std;
void main ()
{
    const int size = 8;
    long double array [size];
    srand (time(0));
    cout << "Array [8] = {";
    for (int i=0; i<size; i++)
    {
        array [i] = rand()%198-99;
        cout << array[i] << ", ";
        if (i==7)
            cout << array[i];
    }
    cout << "}\n\n";
 
    long double sum=0; // лічильник
    for (int i=0; i<size; i++)
    {
        sum+= pow(array[i], (i+1));
    }
    cout << "The sum of the elements of our array,\n";
    cout << "like (array[0]+(array[1])^2+(array[2])^3+...+(array[7])^8): " << sum <<"\n\n";
 
    system ("pause");
}
Код работает, все ОК. Однако в задаче сказано, что в массиве должны использоваться целые отрицательные и положительные числа. таким образом, pow по сути не подходит. Есть ли какая-то альтернатива этой функции для целочисленных элементов типа int?
Заранее спасибо за ответ!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
23.06.2016, 19:14
Ответы с готовыми решениями:

функция pow для int
собственно говоря проблема такая - мне нужно возвести целое число в целую степень. Например я пишу...

Ошибка - перегруженность pow(int,int) неосуществима. Как исправить?
#include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; struct point { int x,y,z; };...

Хочу написать функцию pow(), ошибка: (5,27):Too few parameters in call to 'step(float,int)'
Хочу написать функцию pow(), ошибка: (5,27):Too few parameters in call to 'step(float,int)' float...

Какая из этих функций int Q(int w) int W(int y,int u,int i) сработает быстрее?
Если есть 2 функции(простые или перегруженные) к примеру Q(int w) int W(int y,int u,int i)или int...

18
Диссидент
Эксперт C
27706 / 17322 / 3812
Регистрация: 24.12.2010
Сообщений: 38,979
23.06.2016, 19:19 2
Цитата Сообщение от Техник228 Посмотреть сообщение
Есть ли какая-то альтернатива этой функции для целочисленных элементов типа int?
Конечно, есть!
C++
1
2
3
4
5
6
int PowInt(int x, int n)
{
   int p=1;
   for(int i=0; i<n; i++) p *= x;
   return p;
}
0
2062 / 618 / 41
Регистрация: 23.10.2011
Сообщений: 4,468
Записей в блоге: 2
23.06.2016, 19:22 3
C++
1
2
3
4
5
6
7
8
9
int ipow(int a, int n)
{
    int r = 1;
    for (int i = 0; i < n; i++)
    {
        r *= a;
    }
    return r;
}
0
2 / 2 / 0
Регистрация: 07.06.2016
Сообщений: 63
23.06.2016, 19:29  [ТС] 4
спасибо, конечно! но мы функции еще не учили... ) т.е. можно использовать только стандартные библиотечные... есть другие перегруженные версии этой функции для С++?
0
Диссидент
Эксперт C
27706 / 17322 / 3812
Регистрация: 24.12.2010
Сообщений: 38,979
23.06.2016, 19:31 5
Цитата Сообщение от Техник228 Посмотреть сообщение
мы функции еще не учили.
А ты без функций... Просто вставь код вычисления вместо строчки 24 и будет тебе счастие.
0
7785 / 6553 / 2983
Регистрация: 14.04.2014
Сообщений: 28,617
23.06.2016, 19:33 6
Техник228, в твоём случае нужно просто описать отдельную переменную для a в степени и домножать на a каждую итерацию.
0
Диссидент
Эксперт C
27706 / 17322 / 3812
Регистрация: 24.12.2010
Сообщений: 38,979
23.06.2016, 19:37 7
Цитата Сообщение от nmcf Посмотреть сообщение
в твоём случае
Увы, не катит. Все a - разные, рандомные.

Добавлено через 2 минуты
Хотя, возможно, я не прав. Задание + решение создают путаницу. Надо обращаться к ТС, чтоб он объяснил, что , собственно, надо сделать.
0
2 / 2 / 0
Регистрация: 07.06.2016
Сообщений: 63
23.06.2016, 19:41  [ТС] 8
Цитата Сообщение от Байт Посмотреть сообщение
Просто вставь код вычисления вместо строчки 24 и будет тебе счастие.
ну да, это я и думал делать ранее. но прежде решил спросить у знатоков относительно альтернативы... жаль что таковой нет... , с другой стороны, понимаю почему.
Всем спасибо!

Добавлено через 1 минуту
Цитата Сообщение от Байт Посмотреть сообщение
Задание + решение создают путаницу. Надо обращаться к ТС, чтоб он объяснил, что , собственно, надо сделать.
Заданий одномерный массив А (8) целого типа (положительные и отрицательные). Найти сумму a1 + 2a^2 + 3a^3 + ... + 8a^8.
0
Диссидент
Эксперт C
27706 / 17322 / 3812
Регистрация: 24.12.2010
Сообщений: 38,979
23.06.2016, 19:42 9
Техник228, Ты бы всетки уточнил задание-решение. В задании у тебя все коэфициэнты есть степени одного числа a. А в решении ты им даешь рандомные значения.
0
2062 / 618 / 41
Регистрация: 23.10.2011
Сообщений: 4,468
Записей в блоге: 2
23.06.2016, 19:44 10
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
using namespace std;
 
#define ipow(r, a, n) r = 1;for(int i=0;i<n;i++){r*=a;}
 
int main()
{
    int r;
 
    ipow(r, 10, 3);
 
    cout << r << endl;
 
    return 0;
}
0
2 / 2 / 0
Регистрация: 07.06.2016
Сообщений: 63
23.06.2016, 19:45  [ТС] 11
суть в том, что если использовать рандомные элементы - оценка больше ) вот и пилю под них...
и самому так интересней... )
0
Диссидент
Эксперт C
27706 / 17322 / 3812
Регистрация: 24.12.2010
Сообщений: 38,979
23.06.2016, 19:53 12
Цитата Сообщение от Техник228 Посмотреть сообщение
суть в том, что если использовать рандомные элементы - оценка больше ) вот и пилю под них...
Так ты и задание сформулируй под этот вариант... А то люди никак понять тебя не могут. Задание одно, решается совсем другое...
0
2 / 2 / 0
Регистрация: 07.06.2016
Сообщений: 63
23.06.2016, 19:57  [ТС] 13
Простите, извините. Заданий одномерный массив А (8) целого типа, в котором должны присутствовать положительные и отрицательные элементы целого типа. Найти сумму a1 + 2a^2 + 3a^3 + ... + 8a^8. (все а - это разные рандомные элементы).
вроде ниче не упустил...
0
161 / 153 / 92
Регистрация: 18.11.2015
Сообщений: 677
23.06.2016, 20:03 14
Цитата Сообщение от Техник228 Посмотреть сообщение
Есть ли какая-то альтернатива этой функции для целочисленных элементов типа int?
По-моему, pow() работает с int, нет?

Добавлено через 2 минуты
Техник228, просто измени тип элементов в своем массиве так: int array[size];

Добавлено через 1 минуту
Цитата Сообщение от Техник228 Посмотреть сообщение
рандомные элементы
Рандомные элементы или элементы с рандомным значением?
1
Диссидент
Эксперт C
27706 / 17322 / 3812
Регистрация: 24.12.2010
Сообщений: 38,979
23.06.2016, 20:03 15
Цитата Сообщение от Техник228 Посмотреть сообщение
вроде ниче не упустил...
Придется слегка подправить, чтоб все это имело смысл...
Найти сумму a11 + 2a22 + 3a33 + ... 8a88, где ai - рандомные числа от -99 до 98
Слово "разные" - убери. Оно здорово усложняет задачу
0
7785 / 6553 / 2983
Регистрация: 14.04.2014
Сообщений: 28,617
23.06.2016, 20:06 16
Цитата Сообщение от meJevin Посмотреть сообщение
По-моему, pow() работает с int, нет?
Только не ясно, какой алгоритм там - если через всякие логарифмы, то, наверное, может быть неточный результат.
0
161 / 153 / 92
Регистрация: 18.11.2015
Сообщений: 677
23.06.2016, 20:06 17
Байт, тогда он всего лишь умножение забыл sum += (i+1) * pow(array[i], (i + 1));
0
2062 / 618 / 41
Регистрация: 23.10.2011
Сообщений: 4,468
Записей в блоге: 2
23.06.2016, 20:09 18
> Однако в задаче сказано, что в массиве должны использоваться целые отрицательные и положительные числа
Техник228, пользователь meJevin вам правильно пишет. Используйте INT вместо DOUBLE и не парьтесь.

Добавлено через 1 минуту
Потому что DOUBLE будет неявно преобразован в INT
0
2 / 2 / 0
Регистрация: 07.06.2016
Сообщений: 63
23.06.2016, 20:41  [ТС] 19
Цитата Сообщение от Байт Посмотреть сообщение
Придется слегка подправить, чтоб все это имело смысл...
Найти сумму a11 + 2a22 + 3a33 + ... 8a88, где ai - рандомные числа от -99 до 98
Слово "разные" - убери. Оно здорово усложняет задачу
Заданий одномерный массив А (8) целого типа, в котором должны присутствовать положительные и отрицательные элементы целого типа. Найти сумму a1 + 2a^2 + 3a^3 + ... + 8a^8. (все а - это рандомные элементы).

исправил
p.s. сорри, я совсем зеленый)

Добавлено через 31 минуту
Цитата Сообщение от meJevin Посмотреть сообщение
sum += (i+1) * pow(array[i], (i + 1));
зачем? все норм считается...

Цитата Сообщение от programina Посмотреть сообщение
Потому что DOUBLE будет неявно преобразован в INT
действительно. спасибо большое!
0
23.06.2016, 20:41
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
23.06.2016, 20:41
Помогаю со студенческими работами здесь

при вызове функции pow() выдаёт ошибку: test.cpp:(.text+0x59b): undefined reference to `pow'
В чём дело? Добавлено через 1 минуту ps. Заголовок math.h подключен.

Требуется написать функцию long long pow(long long a, unsigned int p), которая возводит число a в степень p
Требуется написать функцию long long pow(long long a, unsigned int p), которая возводит число a в...

Не работает перегрузка индексного оператора [], вместо [int][int] почему то нужно ставить [0][int][int]
#include&lt;iostream&gt; #include&lt;string&gt; #include&lt;vector&gt; #include&lt;algorithm&gt; #include&lt;ctime&gt;...

Error LNK2019: unresolved external symbol "public: __thiscall Vector<int>::Vector<int>(int,int,int)" (?0?$Vec
Вот есть заголовочный файл // Заголовочный файл Vector.h #ifndef VECTOR_H #define VECTOR_H ...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru