Форум программистов, компьютерный форум CyberForum.ru

Задача на формирование нового массива - C++

Восстановить пароль Регистрация
 
Машенька1
 Аватар для Машенька1
3 / 0 / 0
Регистрация: 19.02.2012
Сообщений: 60
28.02.2012, 20:40     Задача на формирование нового массива #1
Дан массив A размера N. Сформировать новый массив B того же раз-мера по следующему правилу: элемент BK равен сумме элементов массива A с номерами от 1 до K.
Заранее благодарю!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.02.2012, 20:40     Задача на формирование нового массива
Посмотрите здесь:

формирование нового массива C++
Формирование из элементов массива A нового массива B C++
C++ Задача на сформирование нового массива
Задача на формирование матрицы C++
Задача на формирование массива. C++
C++ Формирование нового списка или из pascal -> с++
C++ Задача на формирование списков
Работа с одномерными массивами чисел (сумма, произведение, формирование нового массива) C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
miriganua
129 / 100 / 4
Регистрация: 05.02.2012
Сообщений: 241
28.02.2012, 20:58     Задача на формирование нового массива #2
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>
 
using namespace std;
 
int main(int argc, char * argv[])
{
    const int n = 10;
    double a[n] = {4, 9, -1, 0, 8, 2, 0, 1, -2, 10};
    double b[n];
    for (int k = 0; k < n; k++)
    {
        b[k] = a[0];
        for (int i = 1; i <= k; i++)
        {
            b[k] += a[i];
        }
    }
 
    cout << "Array B:" << '\n';
    for (int i = 0; i < n; i++)
    {
        cout << b[i] << "   ";
    }
    cout << '\n';
    return 0;
}
__bool
 Аватар для __bool
284 / 225 / 6
Регистрация: 13.06.2010
Сообщений: 744
28.02.2012, 20:58     Задача на формирование нового массива #3
Понимаю, что таково условие, но зачем создавать лишний массив, если можно обойтись без него..
Нормальное(имхо) решение:
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 <iostream>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
    const short N = 20; // Размер массива
    int A[N]; // Целочисленный массив из N элементов
    int K, // Заданный номер
    Sum=0;// результат суммирования элементов
    cout << "Input K: ";
    cin >> K;
    for (int i = 0; i < N; ++i) {
        if (i == K) {
            A[K] = Sum;
        }else{
            A[i] = rand()%10; // Генерируем случайные значения
            Sum+=A[i];
        }
        cout << A[i] << "\t"; // И сразу выводим
    }
    cout << "\n\n";
    system("pause");
 
    return 0;
}
Решение с ненужными телодвижениями удовлетворяющее условиям задачи:
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
#include <iostream>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
    randomize();
    const short N = 20; // Размер массива
    int A[N], B[N]; // Массивы из N элементов
    int K, // Заданный номер
    Sum=0;// результат суммирования элементов
    cout << "Input K: ";
    cin >> K;
    // Заполнение массива А случайными значениями
    cout << "\nArray A: \n";
    for (int i = 0; i < N; ++i) {
        A[i] = rand()%10;
        cout << A[i] << "\t"; // И сразу выводим
    }
    cout << "\n\nArray B: \n";
    for (int i = 0; i < N; ++i) {
        if (i == K) {   // Если текущий номер равен заданному
            B[i] = Sum; // Назначаем элементу с заданным номером значение суммы всех предыдущих элементов
        }else{      // Иначе продолжаем суммировать и копировать в массив B элементы массиваA
            B[i] = A[i];
            Sum+=A[i];
        }
        cout << B[i] << "\t"; // И сразу выводим
    }
    cout << "\n\n";
    system("pause");
    return 0;
}
Yandex
Объявления
28.02.2012, 20:58     Задача на формирование нового массива
Ответ Создать тему
Опции темы

Текущее время: 02:53. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru