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

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

25.08.2012, 13:38. Показов 4238. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru