Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
3 / 3 / 1
Регистрация: 24.11.2011
Сообщений: 97

В линейном динамическом массиве уничтожить все совершенные числа

09.06.2012, 13:01. Показов 1137. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В линейном динамическом массиве уничтожить все совершенные числа. Совершенное число (сумма делителей = самому числу) Например 6 = 1 +2 +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
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
53
#include "stdafx.h"
#include <iostream>
 
using namespace std;
 
bool isPerfect(unsigned __int64 uiVal)
{
    unsigned __int64 uiSum = 0;
 
    for (unsigned __int64 i = uiVal / 2; i >= 1; --i)
    {
        if (uiVal % i == 0)
        {
            uiSum += i;
        }
    }
    return uiSum == uiVal;
}
 
unsigned int removePerfect(unsigned __int64* pArr, unsigned int uiSize, unsigned __int64** ppArrNew)
{
    unsigned int uiCount = 0;
    
    if (pArr != NULL || ppArrNew != NULL ||  uiSize != 0) 
    {   
        for (unsigned int i = 0; i < uiSize; i++) 
        {
            if (isPerfect(pArr[i])) 
            {
                *ppArrNew = (unsigned __int64*) realloc(*ppArrNew, (uiCount + 1) * sizeof(__int64));
                (*ppArrNew)[uiCount++] = pArr[i];
            }
        }
    }
    return uiCount;
}
 
int _tmain(int argc, _TCHAR* argv[])
{
    unsigned __int64 uiArr [] = {3343, 5, 28, 496, 44, 6, 8128, 65, 345, 1, 33550336};
    unsigned __int64* pArrNew = NULL;
        
    unsigned int uiCount = removePerfect(uiArr, sizeof(uiArr) / sizeof(__int64), &pArrNew);
 
    for (unsigned int i = 0; i < uiCount; i++)
    {
        cout << pArrNew[i] << endl;
    }
 
    system("pause");
 
    return 0;
}
Добавлено через 17 часов 20 минут
Нуууу...разве никто незнает!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.06.2012, 13:01
Ответы с готовыми решениями:

В линейном массиве уничтожить все элементы находящиеся мие наибольшим и наименьшим элементом
В линейном массиве уничтожить все элементы находящиеся между наибольшим и наименьшим элементом помогите пожалуйсто, очень нужно

В линейном массиве найти четырёхзнычные числа
Дан линейный массив (вводится с клавиатуры), в нём найти все четырёхзначные числа в записи которых присутствуют только разные цифры. ...

В двумерном массиве найти совершенные числа
Написать программу в с++ которая задает двумерный массив(который нужно вводить с клавиатуры) и ищет в нем совершенное число, выводя его на...

6
 Аватар для defer
577 / 256 / 18
Регистрация: 29.11.2010
Сообщений: 868
09.06.2012, 13:19
C++ (Qt)
1
if (!isPerfect(pArr[i]))
0
3 / 3 / 1
Регистрация: 24.11.2011
Сообщений: 97
12.06.2012, 12:07  [ТС]
В линейном динамическом массиве уничтожить все совершенные числа. Совершенное число (сумма делителей = самому числу) Например 6 = 1 +2 +3

Добавлено через 1 час 6 минут
Неужели никто незнает?
0
 Аватар для zitxbit
96 / 748 / 279
Регистрация: 11.04.2012
Сообщений: 971
12.06.2012, 12:16
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
#include <stdio.h>
#include <conio.h>
 
#define N 10
 
int main()
{
    int X[N] = { 6, 5, 8, 10, 496, 28, 9, 8128, 6, 7 };
 
    for (int z = 0; z < N; z++)
        printf("%d ",X[z]);
    printf("\n");
 
    for (int i = 0; i < N; i++)
    {
        int nSum = 0;
        for (int div = 1; div < X[i] && X[i] > 0; div++)
            if ((X[i] % div) == 0)
                nSum+=div;
        
        if (X[i] == nSum && X[i] > 0)
        {
            int k = i;
            while (k < N) X[k++] = X[k+1];
            X[k-1] = 0; i--;
        }
    }
 
    for (int m = 0; X[m] > 0; m++)
        printf("%d ",X[m]);
    printf("\n");
 
    _getch();
 
    return 0;
}
http://liveworkspace.org/code/... 6b7bad0056
1
3 / 3 / 1
Регистрация: 24.11.2011
Сообщений: 97
12.06.2012, 12:36  [ТС]
Цитата Сообщение от zitxbit Посмотреть сообщение
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
#include <stdio.h>
#include <conio.h>
 
#define N 10
 
int main()
{
    int X[N] = { 6, 5, 8, 10, 496, 28, 9, 8128, 6, 7 };
 
    for (int z = 0; z < N; z++)
        printf("%d ",X[z]);
    printf("\n");
 
    for (int i = 0; i < N; i++)
    {
        int nSum = 0;
        for (int div = 1; div < X[i] && X[i] > 0; div++)
            if ((X[i] % div) == 0)
                nSum+=div;
        
        if (X[i] == nSum && X[i] > 0)
        {
            int k = i;
            while (k < N) X[k++] = X[k+1];
            X[k-1] = 0; i--;
        }
    }
 
    for (int m = 0; X[m] > 0; m++)
        printf("%d ",X[m]);
    printf("\n");
 
    _getch();
 
    return 0;
}
http://liveworkspace.org/code/... 6b7bad0056
Спасибо,но надо чтоб в прогу невводились ети числа,а она считала количетво дилителей!

Добавлено через 1 минуту
Цитата Сообщение от kaznachey1993 Посмотреть сообщение
Спасибо,но надо чтоб в прогу невводились ети числа,а она считала количетво дилителей!
Сори,всё правильно,токо масив заьб рандомом!
0
 Аватар для zitxbit
96 / 748 / 279
Регистрация: 11.04.2012
Сообщений: 971
12.06.2012, 12:37
Рандомить массив не советую. Вряд ли rand() сгенерирует эти числа.
1
3 / 3 / 1
Регистрация: 24.11.2011
Сообщений: 97
12.06.2012, 12:39  [ТС]
Цитата Сообщение от zitxbit Посмотреть сообщение
Рандомить массив не советую. Вряд ли rand() сгенерирует эти числа.
Спасибо большое выручил!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.06.2012, 12:39
Помогаю со студенческими работами здесь

Цикл: Вывести все совершенные числа и все пары дружественных чисел из промежутка [2, n].
Число називається досконалим, якщо воно дорівнює сумі всіх своїх дільників, крім самого цього числа (наприклад, 28=1+2+4+7+14). Два числа...

В линейном массиве заменить все элементы на число m (m – индекс максимального элемента)
Первый семестр

Для заданного натурального числа N вывести в столбик все совершенные числа меньшие N c++
Для заданного натурального числа N вывести в столбик все совершенные числа меньшие N. Совершенное число – натуральное число, которое равно...

Как выяснить, содержатся ли в одномерном массиве совершенные числа?
Нужно выяснить, содержатся ли в одномерном массиве совершенные числа. Затем сделать так, чтобы все элементы, не являющиеся совершенными...

Найти все совершенные числа от M до N
Совершенные числа (Время: 1 сек. Память: 16 Мб ) Число называется совершенным, если оно равно сумме всех своих делителей, меньших его...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru