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

Подсчет числа счастливых билетов в различных системах счисления

01.10.2014, 17:56. Показов 1354. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго времени суток всем! Суть моей задачи состоит в следующем: на вход я получаю два числа - number и base, где number - это количество цифр в половине моего билета, а base - это основание системы счисления, в которой нужно будет подсчитать количество этих самых билетов. Моя программа справляется с такими тестами, как 2 10, 3 10, 2 11. Но, к примеру, тест 6 10 выдает неверный результат(926464756 вместо 39581170420). Подозреваю, что проблема в той части кода, где я отнимаю часть от общей суммы билетовю Подскажите, пожалуйста, что может быть не так. Код брался отсюда http://habrahabr.ru/post/189982/. Прилагаю свой исходник:
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 <iostream>
#include <fstream>
#include <boost/multiprecision/cpp_int.hpp>
#define MAX 2000
 
using namespace boost::multiprecision;
using namespace std;
 
void numberCount(int number, int base, int **data) {
     for(int i = 1; i <= number; i++) {
             int length = i * (base - 1) + 1;
             if (i == 1) {
                   for(int j = 0; j < length; j++)
                      data[i][j] = 1;
             }
             else {
                  int sum = 0;
                  int k = 0;
                  for(; k <= length / 2; k++) {
                        sum += data[i - 1][k];
                        if (k >= base)
                          sum -= data[i - 1][k - base];
                        data[i][k] = sum;
                  }
                  for(; k < length; k++) {
                        data[i][k] = data[i][length - 1 - k];
                  }
             }
     }
}
 
int main () {
    int base, number, **data, i = 0;
    cpp_int count = 0;
    ifstream fin("input.txt");
    ofstream fout("output.txt");
    fin >> number;
    fin >> base;
    data = new int *[MAX];
    for (int i = 0; i < MAX; i++) {
       data[i] = new int[MAX];
    }
    for (int i = 0; i < MAX; i++) {
       for (int j = 0; j < MAX; j++) {
          data[i][j] = 0;
       }
    } 
    numberCount(number, base, data);
    for(int i = 0; i <= number * (base - 1); i++) {
       count += data[number][i] * data[number][i];
    }
    fout << count << endl;
}
Добавлено через 46 минут
При изменении типа массива на long тест 6 10 стал проходить, стало быть проблема в типах, которые не могут оперировать такими большими числами, подскажите, что можно сделать...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.10.2014, 17:56
Ответы с готовыми решениями:

Арифмитические операции в различных системах счисления
Помогите решить задачу: Определить подпрограммы сложения и умножения целых чисел, представленных...

Подсчет количества "счастливых" билетов с заданной суммой цифр
Необходимо посчитать количество «счастливых» билетов с заданной суммой цифр, среди тех, номер...

Программа для преобразования чисел в различных системах счисления
Помогите с кодом пожалуйста. Буду благодарен! Реализовать ввод и перевод чисел с троичной в...

Применение функций для вычислений в различных системах счисления
Разработать программу на языке С++ для решения следующей задачи. Заданы два числа — А и B, первое...

0
01.10.2014, 17:56
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.10.2014, 17:56
Помогаю со студенческими работами здесь

Определить количество счастливых билетов
Имеется часть катушки с автобусными билетами. Номер билета 6-ти значный. Составить программу....

Нахождение количества счастливых билетов
Найдите кол-во счастливых билетов типа - XXXXXX Счастливым является билет у которого три первые...

Подсчитать общее количество «счастливых» билетов
Подсчитать общее количество «счастливых» билетов. Билет имеет шестизначный номер и является...

Найти количество всевозможных шестизначных счастливых билетов
Найти количество всевозможных шестизначных счастливых билетов (для простого алгоритма потребуется...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru