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

Для целого числа найти его представление в виде среднего арифметического квадратов чисел

09.07.2014, 12:50. Показов 1451. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Заставляют решить такую задачу:
Для целого числа N найти его представление в виде среднего арифметического квадратов натуральных чисел. Например, 2007=(2^2+12^2+22^2+86^2)/4.
В первой строке ввода содержится одно целое число N (1 ≤ N ≤ 100000).
Вывести в первой строке число K (1 ≤ K ≤ 1000). Во второй строке K натуральных чисел от 1 до 1000, среднее арифметическое квадратов которых равно заданному числу N. Числа могут повторяться. Если существует несколько вариантов, то можно вывести любой из них.
Пример ввода
2007
Пример вывода
4
2 12 22 86

Есть ли алгоритм для решения? Чтобы хоть знать, что писать.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.07.2014, 12:50
Ответы с готовыми решениями:

Для целого числа n найти сумму квадратов его цифр
для целого числа n найти сумму квадратов его цифр,если заданное число четырёхзначное. пожалуйсто как можно быстрее,срочно надо!

Для целого числа n, найти сумму квадратов его цифр. Проверить является ли полученное число четным
Помогите плз)

Для заданного целого десятичного числа N получить его представление в p-ичной системе счисления
нужно написать программу до пятницы . си++ билдер Для заданного целого десятичного числа N получить его представление в p-ичной системе...

4
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
09.07.2014, 13:38
Есть ли алгоритм для решения? Чтобы хоть знать, что писать.
C++
1
2
3
4
5
6
7
N*=4;
while(N)
{
    int M=N>1000*1000?1000:sqrt(N);
    cout<<M<<" ";
    N-=M*M;
}
Не?

Добавлено через 3 минуты
UPD Пардон, не внимательно прочел условия, это только суммирования всех квадратов и деления результата на четыре сработает.
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
10.07.2014, 11:40
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/////////////////////////////////////////////////////////////////////////////////////////
//Для целого числа N найти его представление в виде среднего арифметического квадратов 
//натуральных чисел. Например, 2007=(2^2+12^2+22^2+86^2)/4.
//В первой строке ввода содержится одно целое число N (1 ≤ N ≤ 100000).
//Вывести в первой строке число K (1 ≤ K ≤ 1000). Во второй строке K натуральных чисел 
//от 1 до 1000, среднее арифметическое квадратов которых равно заданному числу N. 
//Числа могут повторяться. Если существует несколько вариантов, то можно вывести любой из них.
//Пример ввода
//2007
//Пример вывода
//4
//2 12 22 86
/////////////////////////////////////////////////////////////////////////////////////////
#include <algorithm>
#include <iostream>
#include <cmath>
#include <map>
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::map<int, int>  T_count_of_val;
/////////////////////////////////////////////////////////////////////////////////////////
void    set_count_of_val
    (
        int                 n,
        T_count_of_val  &   count_of_val
    )
{
    count_of_val.clear();
    double  sqrt_n  =   sqrt    (
                                    double( n )
                                );
 
    int     lower_sqrt          =   int( sqrt_n );
 
    if  (
            lower_sqrt * lower_sqrt == n
        )
    {
        count_of_val[ lower_sqrt ]  =   1;
    }
    else
    {
        int     upper_sqrt          =   lower_sqrt + 1;
 
        int     lower_delta_abs     =   abs( lower_sqrt * lower_sqrt - n );
        int     upper_delta_abs     =   abs( upper_sqrt * upper_sqrt - n );
 
        count_of_val[ lower_sqrt ]  =   upper_delta_abs;
        count_of_val[ upper_sqrt ]  =   lower_delta_abs;
    }
}
/////////////////////////////////////////////////////////////////////////////////////////
template< typename  T >
struct  T_print_val_and_count
{
    //-----------------------------------------------------------------------------------
    int     sum_;
    int     count_;
    //-----------------------------------------------------------------------------------
    T_print_val_and_count()
        :
        sum_    (),
        count_  ()
    {}
    //-----------------------------------------------------------------------------------
    void    operator()  ( T     const   &   t )
    {
        sum_    +=  t.first * t.first * t.second;
        count_  +=  t.second;
 
        std::cout   <<  t.first
                    <<  '\t'
                    <<  t.second
                    <<  " шт"
                    <<  std::endl;
    }
    //-----------------------------------------------------------------------------------
    double  res()
    {
        return  sum_ / double( count_ );
    }
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
void    print_result( T_count_of_val  const   &   count_of_val )
{
    double  result  =   std::for_each
                            (
                                count_of_val.begin                                      (),
                                count_of_val.end                                        (),
                                T_print_val_and_count< T_count_of_val::value_type >     ()
                            )
                            .res();
 
    std::cout   <<  "result = "
                <<  result
                <<  std::endl
                <<  std::endl
                <<  std::endl
                <<  std::endl
                <<  std::endl;
}
/////////////////////////////////////////////////////////////////////////////////////////
int     main()
{
    std::locale::global(std::locale(""));
 
    for(;;)
    {
        std::cout   <<  "Введите n (1..100000): ";
        int     n   =   0;
        std::cin    >>  n;
 
        T_count_of_val  count_of_val;
 
        set_count_of_val
            (
                n,
                count_of_val
            );
 
        print_result( count_of_val );
    }//for
}
0
1 / 1 / 0
Регистрация: 27.11.2014
Сообщений: 16
03.07.2015, 19:03
Mr.X, не рабочий код
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
03.07.2015, 19:27
W910, да ну?
Миниатюры
Для целого числа найти его представление в виде среднего арифметического квадратов чисел  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.07.2015, 19:27
Помогаю со студенческими работами здесь

Найти суммы квадратов чисел от 1 до введенного целого числа N
Составить программу высления суммы квадратов чисел от 1 до введенного целого числа N.

Для заданного целого десятичного числа получить его представление в н-ичной системе счисления (н<10). Рекурсия
Для заданного целого десятичного числа получить его представление в н-ичной системе счисления (н&lt;10).

Найти сумму квадратов чисел от 1 до введенного вами целого числа n
Составьте программу, которая вычисляет сумму квадратов чисел от 1 до введенного вами целого числа n

Найти в файле числа, меньшие среднего арифметического значения всех чисел массива
Создать файл, содержащий 10 вещественных чисел. Найти числа, меньшие среднего арифметического значения всех чисел массива. Вывести их на...

Представление числа в виде суммы двух квадратов
Дано натуральное число. Определить, можно ли представить это число в виде суммы двух квадратов. Если можно, то сделать это. Если нет,...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru