Форум программистов, компьютерный форум, киберфорум
Наши страницы
C для начинающих
Войти
Регистрация
Восстановить пароль
 
FlazyC
0 / 0 / 0
Регистрация: 14.01.2018
Сообщений: 6
1

В массиве A (n) каждый элемент, кроме первого заменить суммой всех предыдущих элементов

13.02.2018, 23:47. Просмотров 394. Ответов 7
Метки нет (Все метки)

В массиве A (n) каждый элемент, кроме первого заменить суммой всех предыдущих элементов. Как дописать конец?
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
#include <stdlib.h>
#include <conio.h>
#include <stdio.h>
 
int main ()               //ввод переменных
{
int n, s ,prom, i;
printf("Введите n: ");
scanf("%d", &n);                   //размерность массива
 
 
 
int *p=new int[n];            //ввод масисва
for(i=0;i<n;i++)
scanf("%d",p[i]);
s=p[0];
for(i=1;i<n;i++)        //обработка данных   в соотвествии с заданием.
{
prom=p[i];
s=s+prom;
p[i]=s;
}
 
getch ();
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.02.2018, 23:47
Ответы с готовыми решениями:

В массиве C (m) каждый третий элемент заменить на полусумму двух предыдущих элементов
Что не так? #include&lt;conio.h&gt; #include&lt;windows.h&gt; #include&lt;stdlib.h&gt; #include&lt;stdio.h&gt; int...

В массиве A[m] каждый второй элемент заменить произведением двух предыдущих
Помогите разобраться что я делаю не так. Я пока не делаю запись массива в файл, разбираюсь как...

В массиве C (m) каждый третий элемент заменить полусумму двух предыдущих
Реализовать программу вычисления суммы элементов матрицы: В массиве C (m) каждый третий элемент...

Заменить каждый нулевой элемент массива А суммой элементов массива В
Даны целочисленные массивы А и В. Заменить каждый нулевой элемент массива А суммой элементов...

Сформировать массив, каждый последующий элемент которого равен сумме всех предыдущих
Даны целые числа N (&gt; 2), A и B. Сформировать и вывести целочисленный массив размера N, первый...

7
ogner
9 / 10 / 3
Регистрация: 26.03.2017
Сообщений: 69
14.02.2018, 00:07 2
FlazyC, Создай вложенный цикл, в котором ты будешь находить сумму элементов и после выхода из цикла сохранять сумму в ячейку от куда начал считать сумму. И так до конца. То есть последний элемент массива у тебя должен остаться без изменения.
0
Hitoku
1716 / 1312 / 1403
Регистрация: 28.10.2016
Сообщений: 4,265
Завершенные тесты: 4
14.02.2018, 02:23 3
Цитата Сообщение от ogner Посмотреть сообщение
То есть последний элемент массива у тебя должен остаться без изменения
а надо
Цитата Сообщение от FlazyC Посмотреть сообщение
каждый элемент, кроме первого
Добавлено через 6 минут
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 <locale.h>
#include <stdlib.h>
#include <time.h>
 
int main()
{
    srand(time(NULL));
    setlocale(LC_ALL, "rus");
    int n;
    printf("Введите n: ");
    scanf_s("%d", &n);
    int *a = (int*)malloc(n * sizeof(int));
    if (a == NULL) return -1;
    for (int i = 0; i < n; i++) {
        a[i] = rand() % 30 - 15;
        printf("%i ", a[i]);
    }
    printf("\n");
    for (int i = 0; i < n; i++) {
        if (i > 0) a[i] += a[i - 1];
        printf("%i ", a[i]);
    }
    free(a);
    getch();
    return 0;
}
0
MansMI
1451 / 1160 / 550
Регистрация: 08.01.2012
Сообщений: 4,509
14.02.2018, 07:53 4
возможно сумма не измененных элементов?
C
1
2
3
4
for(i=n-1; i>=1; i--)
  if(i==n-1)
    for(j=0; j<i; j++) a[i]+=a[j];
  else a[i]=a[i+1]-a[i];
Добавлено через 34 минуты
C
1
for(a[i]=j=0; j<i; j++) a[i]+=a[j];
0
stake-k26
618 / 432 / 332
Регистрация: 25.04.2016
Сообщений: 1,218
14.02.2018, 14:22 5
Hitoku, сумма всех предыдущих никак не может включать в себя текущий элемент. А вы считаете и его. На мой взгляд вариант с вложенным циклом самый удобоваримый, т.е. что-то вроде этого:
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#include <stdio.h>
#include <stdlib.h>
//#include <conio.h>
 
/* *****************************************************************
 * В массиве A(n) каждый элемент, кроме первого заменить суммой всех
 * предыдущих элементов.
 * ****************************************************************/
void print_arr (int * a, int n)         // массив на экран
{
    int i;
    for (i=0; i<n; i++)
        printf("%3d", a[i]);
    printf("\n");
}
 
int main (void)
{
    int i, k;   // счетчики
    int n, s;   // размер массива, сумма
 
    printf("Введите n: ");
    scanf("%d", &n);            // размер массива
    if (n < 1) return -1;   // нулевой размер массива
 
    int * a;                        // указатель на массив
    if ((a = (int *) malloc(sizeof(int) * n)) == NULL) return -1;
 
    for (i=0; i<n; i++)     // получаем элементы массива с клавиатуры
    {
        printf("a[%i] = ", i);
        scanf("%i", &a[i]);
    }
 
    print_arr(a, n);            // массив на экран
 
    for (i=1; i<n; i++)     // каждый элемент = сумма всех предыдущих
    {
        for (k=s=0; k<i; k++)
            s += a[k];
        a[i] = s;
    }
 
    print_arr(a, n);            // массив на экран
    free(a);                        // освобождаем память
    return 0;
}
печать массива на экран вынесена отдельной функцией просто, чтобы не засорять код.

или для Linux:
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
32
33
34
35
36
37
38
39
40
41
42
43
44
#include <stdio.h>
//#include <stdlib.h>
//#include <conio.h>
 
/* *****************************************************************
 * В массиве A(n) каждый элемент, кроме первого заменить суммой всех
 * предыдущих элементов.
 * ****************************************************************/
void print_arr (int * a, int n)         // массив на экран
{
    int i;
    for (i=0; i<n; i++)
        printf("%3d", a[i]);
    printf("\n");
}
 
int main (void)
{
    int i, k;   // счетчики
    int n, s;   // размер массива, сумма
 
    printf("Введите n: ");
    scanf("%d", &n);            // размер массива
    if (n < 1) return -1;
 
    int a[n];                   // массив
    for (i=0; i<n; i++)     // получаем элементы массива с клавиатуры
    {
        printf("a[%i] = ", i);
        scanf("%i", &a[i]);
    }
 
    print_arr(a, n);            // массив на экран
 
    for (i=1; i<n; i++)     // каждый элемент = сумма всех предыдущих
    {
        for (k=s=0; k<i; k++)
            s += a[k];
        a[i] = s;
    }
 
    print_arr(a, n);            // массив на экран
    return 0;
}
Добавлено через 5 минут
FlazyC, такое объявление массивов
Цитата Сообщение от FlazyC Посмотреть сообщение
int *p=new int[n]; //ввод масисва
характерно для с++, но никак не для си.
0
Hitoku
1716 / 1312 / 1403
Регистрация: 28.10.2016
Сообщений: 4,265
Завершенные тесты: 4
14.02.2018, 14:51 6
stake-k26, да, с учётом текущего действительно косяк...
Даже если так, то всё равно зачем для каждого элемента каждый раз прогонять цикл для поиска суммы?
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 <locale.h>
#include <stdlib.h>
#include <time.h>
 
int main()
{
    srand(time(NULL));
    setlocale(LC_ALL, "rus");
    int n;
    printf("Введите n: ");
    scanf_s("%d", &n);
    int *a = (int*)malloc(n * sizeof(int));
    if (a == NULL) return -1;
    for (int i = 0; i < n; i++) {
        a[i] = rand() % 30 - 15;
        printf("%i ", a[i]);
    }
    printf("\n");
    int sum = a[0];
    for (int i = 0; i < n; i++) {
        if (i > 0) {
            int temp = a[i];
            a[i] = sum;
            sum += temp;
        }
        printf("%i ", a[i]);
    }
    free(a);
    getch();
    return 0;
}
0
stake-k26
618 / 432 / 332
Регистрация: 25.04.2016
Сообщений: 1,218
14.02.2018, 14:55 7
Это проще для понимания, понятно, что по-хорошему число проходов нужно минимизировать. Да и вообще я бы все сделал одним циклом, т.е. ввод значений, рассчет суммы и вывод результата на экран, но тогда читать код будет довольно сложно, особенно новичку.
0
Вадим Тукаев
116 / 119 / 79
Регистрация: 23.01.2018
Сообщений: 411
18.02.2018, 08:08 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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
#define N 10
 
int main(void)
{
    srand(time(NULL));
    int a[N];
    int i;
    for (i = 0; i < N; ++i) {
        printf("%d%c", a[i] = rand() % 100, i == N - 1 ? '\n' : ' ');
    }
    int sum = 0;
    int prev;
    for (i = 0; i < N; ++i) {
        sum += a[i];
        if (i != 0) a[i] = prev;
        prev = sum;
    }
    for (i = 0; i < N; ++i) {
        printf("%d%c", a[i], i == N - 1 ? '\n' : ' ');
    }
    return 0;
}
0
18.02.2018, 08:08
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.02.2018, 08:08

Подсчитать количество элементов, каждый из которых не больше всех предыдущих
Здравствуйте. Помоги пожалуйста с заданием. Дан числовой массив из n элементов. Подсчитать...

В массиве А(n) каждый элемент, кроме первого, заменить суммой всех предыдущих элементов
помогли пожалуйста. мне помогли написать программу, но не совсем правильно, не могли бы помочь...

В массиве A(n) каждый элемент, кроме первого, заменить суммой всех предыдущих элементов
Требуется написать программу в Лазарус. В массиве A(n) каждый элемент, кроме первого, заменить...


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

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

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