Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
Mines
0 / 0 / 0
Регистрация: 25.08.2012
Сообщений: 8
1

не работает sqrt декомпозиция

25.08.2012, 13:38. Просмотров 2156. Ответов 6
Метки нет (Все метки)

Добрый день, пытался разобраться с sqrt-декомпозицией. Суть понял, но вот код не хочет работать. точнее он не хочет работать правильно.
вот код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include<iostream>
#include<cmath>
#include<cstdlib>
#include<cstdio>
 
 
using namespace std;
 
int main() {
    int n ;
    cin>>n;
    int mas_1[n];
    for (int i = 0; i<n; i++)
        cin>>mas_1[i];
        
    int len = (int)sqrt(n) + 1;
    int mas_2[n];
    for (int i = 0; i < n; i++)
        {
        mas_2[i / len] += mas_1[i];
        cout<<mas_2[i]<<' ';
        }
}
input:
8
3 4 8 7 1 6 1 6
(все через пробел)
output:3 25350624 -1080283792 6 7 134515024 -1080283848 8

А должно же быть нормальные промежутки, то есть во втором массиве первый элемент должен быть равен 15. второй 14 и так далее.
Вопрос - почему так выводит и что я сделал неправильно?
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.08.2012, 13:38
Ответы с готовыми решениями:

Цикл: Для числа N вычислить значение следующего выражения: sqrt((1) + sqrt((2) + ... + sqrt(2 * N)))
Как это решить? sqrt((1)+sqrt((2)+..+sqrt(2n)))

Вычислить значение выражения sqrt (2 + sqrt (2 + sqrt (2 ... sqrt2))), (n-слагаемых)
Вычислить значение выражения sqrt (2 + sqrt (2 + sqrt (2 ... sqrt2))),...

Рекурсия: вычислить значение выражения sqrt(1+sqrt(2+...sqrt(n)))
Вычислить с помощью рекурсии и без нее - y(n) = sqrt(1+sqrt(2+...sqrt(n).. Как...

Дано натуральное число n. Вычислить sqrt(2+ sqrt(5 + sqrt(7...))
Дано натуральное число n.Вычислить sqrt(2+ sqrt(5 + sqrt(7...)). Под корнями...

Рекурсия: вычисление sqrt(1 + sqrt(2 + ... + sqrt(n)))
Не подскажите как расписать рекурсивно формулу? Спасибо!

6
OhMyGodSoLong
~ Эврика! ~
1247 / 996 / 74
Регистрация: 24.07.2012
Сообщений: 2,002
25.08.2012, 13:48 2
Не инициализировали mas_2. В результате там чёрти что хранится. В Си++ значение неинициализированных локальных переменных не определено. Это не нули или что-то ещё. Надо прописывать руками, что там должны быть нули. Например, так:
int mas_2[n] = { 0 };
Хотя, по идее, это не работает для variable-sized массивов, так что придётся писать цикл for, который всем выставит нули.
0
Intel~lect
135 / 124 / 14
Регистрация: 03.07.2012
Сообщений: 355
25.08.2012, 13:48 3
Разве эта программа компилируется?! Размер массива должен быть константой
Цитата Сообщение от Mines Посмотреть сообщение
int n ;
cin>>n;
int mas_1[n];
0
Dani
1393 / 637 / 134
Регистрация: 11.08.2011
Сообщений: 2,299
Записей в блоге: 2
Завершенные тесты: 1
25.08.2012, 13:52 4
Intel~lect, оно будет компилиться в некоторых компиляторах, хоть это не по стандарту.

Добавлено через 23 секунды

Не по теме:

я сам раньше так делал :)

0
OhMyGodSoLong
~ Эврика! ~
1247 / 996 / 74
Регистрация: 24.07.2012
Сообщений: 2,002
25.08.2012, 13:52 5
Эта фишка поддерживается некоторыми компиляторами, тем же g++. Но в стандарт C++ не входит (зато есть в C99, хотя и там она помечена как опциональная).
0
4iFF
25.08.2012, 14:41
  #6

Не по теме:


Цитата Сообщение от Mines Посмотреть сообщение
он не хочет работать правильно.
Программа всегда, если работает, то работает правильно.Это программист может не правильно думать.:wall:

0
Mines
0 / 0 / 0
Регистрация: 25.08.2012
Сообщений: 8
26.08.2012, 02:03  [ТС] 7
Вот учел поправку ~OhMyGodSoLong~
Вот стало так:
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
#include<iostream>
#include<cmath>
#include<cstdlib>
#include<cstdio>
 
 
using namespace std;
 
int main() {
    int n ;
    cin>>n;
    int mas_1[n];
    for (int i = 0; i<n; i++)
        cin>>mas_1[i];
 
    int len = (int)sqrt(n) + 1;
    int mas_2[n];
    for (int i =0; i<n; i++)
        mas_2[i] = 0;
 
    for (int i = 0; i < n; i++)
        {
        mas_2[i / len] = mas_1[i] + mas_2[i/len];
        cout<<mas_2[i]<<' ';
        }
}
Но теперь в output при том же самом примере выдает mas_2[0] = 3 а остальные элементы массива заполнены нулями, то есть их значение не изменились. В чем причина?
Если кто-то знает, как правильно напистаь sqrt-декомпозицию - прошу помочь и\или поделится кодом. Спасибо!

Добавлено через 9 часов 41 минуту
Думал, это причина в том, что объявляю массив не верно. Решил попробовать статически объявить:
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
#include<iostream>
#include<cmath>
#include<cstdlib>
#include<cstdio>
 
 
using namespace std;
 
int main() {
    /*
    int n ;
    cin>>n;
    */
    int mas_1[8] = {3,4,8,7,1,6,1,6};
    /*
    for (int i = 0; i<n; i++)
        cin>>mas_1[i];
    */
    int len = (int)sqrt(8) + 1;
    int mas_2[8];
    for (int i =0; i<8; i++)
        mas_2[i] = 0;
 
    for (int i = 0; i < 8; i++)
        {
        mas_2[i / len] = mas_1[i] + mas_2[i/len];
        cout<<mas_2[i]<<' ';
        }
}
В результате выдает то же, что и во второй раз - первый элемент = 3, а остальные = 0
В чем причина???
0
26.08.2012, 02:03
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.08.2012, 02:03

[C++ Error] Sqrt x.cpp(16): E2268 Call to undefined function 'sqrt'. Что это за ошибка???
Когда я испльзую функцию sqrt() компилятор выводит: Sqrt x.cpp(16): E2268 Call...

Вычислить y=sqrt(1+sqrt(4+sqrt(9+.+sqrt(36+sqrt(49)
Помогите пожалуйста с решением данной задачи. ...

Рекурсия S=sqrt(1+sqrt(2+sqrt(3+.+sqrt(n)
Задали написать программу на С++ которая высчитывает...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru