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

Найти суммарное число цифр во всех целых числах от M до N включительно

23.12.2017, 13:12. Показов 2678. Ответов 0
Метки с (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
#include <fstream> 
using namespace std;
int main()
{
    long long M, N, tmp1, tmp2; //Создаем 4 переменные, у которых вместимость больше, чем 10^15. 
    long long result = 0; //Создаем переменную под результат
    int kol1 = 0, kol2 = 0;
    char *file = "input.txt";
    char *file2 = "output.txt"; //Создаем указатели на входной и выходной файлы
    ifstream ifs(file);
    ofstream ofs(file2); //Инициализируем потоки ввода, вывода 
    ifs >> M; //Считываем из входного файла первое число
    ifs >> N; //Второе число
    if (M > N) //Если первое число меньше второго, то выводим ошибку и выходим из программы
    {
        cout << "Bad data" << endl;
        return 1;
    }
    tmp1 = M;
    tmp2 = N; //Заносим во временные переменные два считанных числа
    while (tmp1 != 0) //В цикле считаем сколько цифр в первом числе. Цикл до тех пор, пока tmp1 не станет равно нулю
    {
        tmp1 = tmp1 / 10; //Убираем правую цифру
        kol1++; //Прибавляем к счетчику единицу. На выходе из цикла - количество цифр в числе
    }
    while (tmp2 != 0) //Аналогично со вторым числом
    {
        tmp2 = tmp2 / 10;
        kol2++;
    }
    for (int i = kol1; i <= kol2; i++) //Цикл от найденного kol1 - количества цифр в первом числе, до kol2 - количества цифр во втором числе
    {
        if (kol1 != kol2)
        {
            if (i != kol2) //Если текущее количество цифр в числе не равно kol2, то
            {
                if (i == kol1) result = (pow(10, i) - M) * i; //Если текущее количество цифр равно kol1, то находим сколько чисел между первым числом и первым числом на порядок больше. Полученную разность умножаем на i - количество цифр в каждом числе. Например 111...999 (включительно) - 3*(1000-111)
                else
                    result = result + i*(pow(10, i) - pow(10, i - 1)); //Иначе должны найти количество чисел с текущим количеством цифр и умножить на само количество цифр. Например, 1000...9999. Количество находится как 4*(10000-1000) (где 4 это i)
            }
            else
            {//Здесь, если количество цифр в исходных числах не равно, происходит последнее действие
                //Пример 18 674074072007408
                long long tmps = i*(N - pow(10, i - 1) + 1); //8611111080111135 - это в result перед последним шагом
                cout << result <<" " << tmps << endl;        //1388888888888864 - это значение того, что прибавится на последнем шаге
                                                             //9999999968999999 - получается, если сложить самому
                                                             //9999999969000000 - результат, который получается у программы
                                                             //ПОЧЕМУ??
                result = result + i*(N - pow(10, i - 1) + 1); //Если i=kol2, то надо найти, сколько чисел между наименьшим числом с текущим количетсвом цифр и вторым числом. Разность умножаем на количество цифр 
            }
        }
        else
            result = (N - M + 1)*i;
    }
    cout << "Result is: " << result << endl; //Печать ответа в консоль
    ofs << result; //Вывод в файл
    system("pause");
    return 0;
}
Помогите, пожалуйста, исправить, чтобы результат на тесте 18 674074072007408 был 9999999968999999

Добавлено через 1 час 32 минуты
Программа работает, всё считает, но на тесте 18 674074072007408 выходит: 9999999969000000, а должно быть 9999999968999999
Помогите, пожалуйста, чайнику
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.12.2017, 13:12
Ответы с готовыми решениями:

Найти суммарное число цифр во всех целых числах от m до n включительно
найти суммарное число цифр во всех целых числах от m до n включительно. Помогите написать программу

Даны два целых числа А и В (A<B). Найти произведение всех целых чисел от А до В включительно
помогите

Даны два целых числа A и B (A < B). Найти сумму всех целых чисел от A до B включительно
Здравствуйте. Проверьте пожалуйста эту задачу Даны два целых числа A и B (A &lt; B). Найти сумму всех целых чисел от A до B включительно....

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.12.2017, 13:12
Помогаю со студенческими работами здесь

Даны два целых числа А и В (A<B). Найти произведение всех целых чисел от А до В включительно
Помогите Пожалуйста

Даны два целых числа A и B (A < B). Найти сумму всех целых чисел от A до B включительно
Желательно сделать в Pascal или Delphi

Даны два целых числа A и B (A < B). Найти сумму всех целых чисел от A до B включительно
Даны два целых числа A и B (A &lt; B). Найти сумму всех целых чисел от A до B включительно. как это реализовать на с++??

Даны два целых числа A и B (A < B). Найти сумму всех целых чисел от A до B включительно
(For) Даны два целых числа A и B (A &lt; B). Найти сумму всех целых чисел от A до B включительно.

Даны два целых числа А и В (А<В). Найти сумму квадратов всех целых чисел от А до В включительно
Даны два целых числа А и В (А&lt;В). Найти сумму квадратов всех целых чисел от А до В включительно.


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Чистый C и C++ в Qt Creator: ставим среду без VPN и настраиваем MinGW/CMake, без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru