Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.90/21: Рейтинг темы: голосов - 21, средняя оценка - 4.90
0 / 0 / 0
Регистрация: 25.08.2012
Сообщений: 8

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

25.08.2012, 13:38. Показов 4303. Ответов 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
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.08.2012, 13:38
Ответы с готовыми решениями:

Вычислить значение выражения: sqrt(3+sqrt(6+.+sqrt(96+sqrt(99)
Пытаюсь решить данное выражение, но ответ выходит слишком большим, вот наработка: #include &lt;iostream&gt; #include &lt;math.h&gt; ...

Цикл: Для числа 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))), (n-слагаемых),с помощью iostream, stdio.С помощью цикла for або while

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

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

Не по теме:

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

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

Не по теме:


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

0
0 / 0 / 0
Регистрация: 25.08.2012
Сообщений: 8
26.08.2012, 02:03  [ТС]
Вот учел поправку ~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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.08.2012, 02:03
Помогаю со студенческими работами здесь

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

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

Вычислить значение выражения: Sqrt(x+sqrt(x+.sqrt(x) на с++
Для данного натурального N и вещественного x(x&gt;0) вычислить значение выражения: Sqrt(x+sqrt(x+...sqrt(x))) на с++ или си

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

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru