С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.52/21: Рейтинг темы: голосов - 21, средняя оценка - 4.52
1296 / 469 / 151
Регистрация: 24.08.2011
Сообщений: 2,249
1

Просуммировать количество точек в наборе домино, где количество точек на каждом конце может быть от 1 до n

11.11.2014, 11:10. Показов 3854. Ответов 25
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Посмотрев на ряд костяшек, расположенный в лексикографическом порядке, видна формула этой суммы: 2*n*сумма(от 1 до n):
Код
1 1 1 2 2 2 3 3 3
1 2 3 1 2 3 1 2 3
Однако программа не проходит уже второй тест (тесты неизвестны):
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
using namespace std;
 
int sum(int n)
{
    return (n+1)*(n/2) + (n%2 == 1? (n+1)/2 : 0);
}
 
int main()
{
    int n;
    cin >> n;
    cout << 2*n*sum(n);
    return 0;
}
В чем дело?
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
11.11.2014, 11:10
Ответы с готовыми решениями:

Найти количество точек на всех костяшках домино
Прикладываю фото с задачей. Заранее спасибо! Необходимо сделать на Pascal.

Задать n точек. Найти m=3,4... точек и построить на них m-угольник такой что, количество точек , лежащих внутри и вне m-угольника , минимально различа
Задать n точек. Найти m=3,4... точек и построить на них m-угольник такой что, количество точек ,...

Посчитать количество точек, что находятся в каждом из треугольников
Дана случайное множество точек и диагонали экрана. Посчитать количество точек, что находятся в...

В заданном множестве точек плоскости найти количество точек в каждой из четвертей
В заданном множестве точек плоскости найти количество точек в каждой из четвертей

25
1296 / 469 / 151
Регистрация: 24.08.2011
Сообщений: 2,249
13.11.2014, 10:12  [ТС] 21
Author24 — интернет-сервис помощи студентам
Ilot, неправда, результат правильный, прошел все тесты
0
221 / 166 / 47
Регистрация: 17.07.2012
Сообщений: 587
13.11.2014, 13:07 22
Ilot, 1) чем она малоэффективная? если есть решение быстрее, то кидайте. это решение я написал исходя из ограничений и оно прошло все тесты.
0
323 / 49 / 28
Регистрация: 07.09.2014
Сообщений: 217
13.11.2014, 13:51 23
Тут есть еще один вариант, не уверен правда что он лучше, но все же на первый взгляд работает.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
using namespace std;
 
int Sum(int n){
    int sum = 0;
    if (n>2){
        sum = n*(3*n - 1) + Sum(n-1);
        return sum;
    }
    else {
        return 12;
    }
}
 
int main() {
    for (int i = 2;i<7;i++){
        cout << Sum(i) << endl;
    }
}
Дает ответы для n = 2 to 6 соответственно 12 36 80 150 252
Основано всё на статистическом наблюдении о том, что при переходе числа точек с n до n+1 сумма увеличивается на n(3n - 1). То есть при увеличении n с 2 до 3 сумма увеличивается на 3*(3*3-1) = 24 относительно суммы с n = 2, с 3 до 4 на 4*(3*4-1) = 44 относительно суммы с n = 3 и т.д.
0
221 / 166 / 47
Регистрация: 17.07.2012
Сообщений: 587
13.11.2014, 14:00 24
mihey1993, правильный ответ при n == 3 -> 30. читайте мой коммент про правильность постановки выше, пример у ТС неправильно написан для n == 3.


Керра,
еще одно xD.

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
#include <iostream>
 
using namespace std;
 
int main(){
    long long n;
    cin >> n;
 
    cout << (n + 2) * (n * n + n) / 2;
 
    return 0;
}
0
323 / 49 / 28
Регистрация: 07.09.2014
Сообщений: 217
13.11.2014, 15:43 25
Прошу прощения, не заметил - тогда извратимся вот так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
using namespace std;
 
int Sum(int n){
    int sum = 0;
    if (n>2){
        return n*(10 + 0.5*(10+n-4)*(n-3));
    }
    else {
        return 12;
    }
}
 
int main() {
    for (int i = 2;i<7;i++){
        cout << Sum(i) << endl;
    }
    return 0;
}
0
Эксперт по математике/физикеЭксперт С++
2206 / 1411 / 411
Регистрация: 16.05.2013
Сообщений: 3,597
Записей в блоге: 6
13.11.2014, 17:09 26
Цитата Сообщение от Керра Посмотреть сообщение
Ilot, неправда, результат правильный, прошел все тесты
Может быть потому, что вы немного не точно указали в сабже условие? Вариант без циклов:
C++
1
2
3
4
5
6
7
#include <iostream>
int main() {
    long long n;
    std::cin >> n;
    std::cout << ((n * (n + 1) * (n + 2)) >> 1);
    return 0;
}
0
13.11.2014, 17:09
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.11.2014, 17:09
Помогаю со студенческими работами здесь

Задано N точек на плоскости: подсчитать количество точек попавших в заданную область
1. Записать логическое выражение соответствующие заданной области истинности 2. Составить...

В заданном множестве точек плоскости найти количество точек в каждой из четвертей
В заданном множестве точек плоскости найти количество точек в каждой из четвертей. Знаете я не...

Среди трех точек с координатами (x1,y1), (x2,y2), (x3,y3) определить количество точек, лежащих в третьей четверти
Среди трех точек с координатами (x1,y1), (x2,y2), (x3,y3) определить количество точек, лежащих в...

Дано n точек, определить какое максимальное количество точек лежит на одной прямой
Дано n точек, определить какое максимальное количество точек лежит на одной прямой.


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

Или воспользуйтесь поиском по форуму:
26
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru