1 / 1 / 1
Регистрация: 15.10.2010
Сообщений: 8
1

Как найти сумму цифр элементов массива?

27.01.2012, 13:46. Показов 11405. Ответов 8
Метки нет (Все метки)

Во общем есть массив целых чисел нужно каждый его элемент заменить суммой цифр значения этого элемента. Подскажите пожалуйста как это сделать?
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.01.2012, 13:46
Ответы с готовыми решениями:

Найти сумму тех элементов массива, цифровая запись которых дает четную сумму цифр, а также найти максимальный элемент массива
Вот, что есть.Помогите довести до ума! #include <cstdlib> #include <iostream> #include...

Найти сумму тех элементов массива, цифровая запись которых дает четную сумму цифр
Дан массив натуральных чисел А(N), значения элементов которого лежат в диапазоне . Найти сумму тех...

Найти сумму элементов массива, имеющих ровно K цифр
Не могу составить цикл, который будет считать сумму элементов с нужным количеством цифр. #include...

Найти сумму цифр всех элементов массива
пользователь вводит размерность и элементы одномерного массива натуральных чисел. найти сумму цифр...

8
Эксперт С++
5049 / 3110 / 271
Регистрация: 11.11.2009
Сообщений: 7,045
27.01.2012, 14:04 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
27
28
29
30
31
32
33
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
 
class SumOfDigits : public std::unary_function<int, int>
{
public:
    virtual int operator()(int num) const
    {
        int sum = 0;
        
        while (num != 0)
        {
            sum += num % 10;
            num /= 10;
        }
        
        return sum;
    }
};
 
int main()
{
    std::vector<int> vec((std::istream_iterator<int>(std::cin)), std::istream_iterator<int>());
    
    std::transform(vec.begin(), vec.end(), vec.begin(), SumOfDigits());
    
    std::copy(vec.begin(), vec.end(), std::ostream_iterator<int>(std::cout, "  "));
    std::cout << std::endl;
    
    return 0;
}
0
1 / 1 / 1
Регистрация: 15.10.2010
Сообщений: 8
27.01.2012, 14:06  [ТС] 3
Спасибо Большое!
0
Эксперт С++
5049 / 3110 / 271
Регистрация: 11.11.2009
Сообщений: 7,045
27.01.2012, 14:14 4
А вот об этом заранее писать надо.

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
#include <stdio.h>
 
int sum_of_digits(int num)
{
    int sum = 0;
    
    while (num != 0)
    {
        sum += num % 10;
        num /= 10;
    }
    
    return sum;
}
 
void transform(int *begin, int *end, int (*func)(int))
{
    while (begin != end)
    {
        *begin = func(*begin);
        
        ++begin;
    }
}
 
#define SIZE 5
 
int main(void)
{
    int arr[SIZE];
    
    size_t i;
    
    for (i = 0; i < SIZE; ++i)
        scanf("%d", &arr[i]);
    
    transform(arr, arr + SIZE, sum_of_digits);
    
    for (i = 0; i < SIZE; ++i)
        printf("%d  ", arr[i]);
    
    printf("\n");
    
    return 0;
}
0
Фрилансер
Эксперт С++
5843 / 1224 / 499
Регистрация: 23.11.2010
Сообщений: 3,375
Записей в блоге: 1
27.01.2012, 14:29 5
Как вариант использовать лямбду

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 <vector>
#include <algorithm>
#include <iterator>
 
int main()
{
    std::vector<int> vec((std::istream_iterator<int>(std::cin)), std::istream_iterator<int>());   
    std::transform(vec.begin(), vec.end(), vec.begin(), [] (int num)
    {
        int sum = 0;
        while(num)
        {
            sum += num % 10;
            num /= 10;
        }
        return sum;
    });    
    std::copy(vec.begin(), vec.end(), std::ostream_iterator<int>(std::cout, "  "));
    std::cout << std::endl;
    system("pause");
    return 0;
}
0
Эксперт С++
5049 / 3110 / 271
Регистрация: 11.11.2009
Сообщений: 7,045
27.01.2012, 14:41 6
Dekio, а я специально не стал лямбды использовать. Как по мне, так они удобны для коротеньких предикатов (в 1-2 строчки), а для длинного предиката мне удобнее честно создать класс (в который, по сути, лямбда в итоге и развернётся). ИМХО.
0
34 / 34 / 8
Регистрация: 22.09.2013
Сообщений: 170
27.09.2013, 06:36 7
silent_1991,
C++ (Qt)
1
2
3
4
5
6
7
8
void transform(int *begin, int *end, int (*func)(int))
{
    while (begin != end)
    {
        *begin = func(*begin);
        
        ++begin;
    }
хотела спросить как эту часть вашеи программы можно изменить для двумерного массива:?
сспосибо заранее
1
Эксперт С++
5049 / 3110 / 271
Регистрация: 11.11.2009
Сообщений: 7,045
27.09.2013, 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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#include <stdio.h>
 
int sum_of_digits(int num)
{
    int sum = 0;
    
    while (num != 0)
    {
        sum += num % 10;
        num /= 10;
    }
    
    return sum;
}
 
void transform(int *begin, int *end, int (*func)(int))
{
    while (begin != end)
    {
        *begin = func(*begin);
        
        ++begin;
    }
}
 
#define ROWS 3
#define COLS 3
 
void transform2(int arr[][COLS], int (*func)(int))
{
    int i;
    
    for (i = 0; i < ROWS; ++i)
        transform(arr[i], arr[i] + COLS, func);
}
 
int main(void)
{
    int arr[ROWS][COLS] = { { 111, 112, 113 }, { 114, 115, 116 }, { 117, 118, 119 } };
    int i, j;
    
    transform2(arr, sum_of_digits);
    
    for (i = 0; i < ROWS; ++i)
    {
        for (j = 0; j < COLS; ++j)
            printf("%d  \t", arr[i][j]);
        printf("\n");
    }
    
    return 0;
}
1
34 / 34 / 8
Регистрация: 22.09.2013
Сообщений: 170
27.09.2013, 19:44 9
у меня само задача выглядела так :
Найти номер столбца матрицы, сумма цифр элементов которого минимальна
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
int main(int argc, char* argv[])
{ int a[20][20];
int i,j,n;
cout<<"massiv joldar  engiz";
cin>> n;
cout<<"massiv " <<"\n"   ;
for (i=0;i<n;i++){
for (j=0; j<n; j++) {
//cin>>a[i][j];
a[i][j]=rand()%20-1;
cout<<a[i][j]<< "\t"; }
cout<<"\n\n\n"; }
int sum,num,mincifr=100, jm;
 for (i=0;i<n;i++) {
  for (j=0; j<n; j++) {
  sum=0;
  num = a[i][j];
  while (num != 0)
    {  sum += num % 10;
        num /= 10;
    }
      if (sum<mincifr ) {
mincifr=sum;
jm=j;   }
}}
cout<<mincifr;
cout<<"   jmin   "<<jm;
 
       getch();
        return 0;
}
и я так решила , без функции)))))
silent_1991, спасибо и ваш метод поробую ))))
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
27.09.2013, 19:44
Помогаю со студенческими работами здесь

Найти сумму трехзначных элементов массива, сумма цифр которых меньше 10
Дан массив из n элементов. Каждый элемент может принимать целочисленные значения от 0 до1000....

Найти сумму трехзначных элементов массива, произведение цифр которых меньше 30
Дан массив из n элементов. Каждый элемент может принимать целочисленные значения от 0 до1000....

Найти сумму положительных элементов массива, значения которых состоят из двух цифр
задание: 1.Дан массив целых чисел из n элементов, заполненный случайным образом числами из...

Найти сумму положительных элементов массива, значения которых состоят из двух цифр
Есть задание 1. Дан массив целых чисел из n элементов, заполненный случайным образом числами...

В заданном одномерном массиве целого типа найти и напечатать сумму цифр всех элементов массива
В заданном одномерном массиве целого типа найти и напечатать сумму цифр всех элементов массива....

Найти сумму таких элементов последовательности, которые делятся на сумму своих цифр
Количество элементов в этой последовательности заранее неизвестно, потому нельзя использовать...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru