Форум программистов, компьютерный форум CyberForum.ru

сложение Элементов числа, шахматная доска, счастливые числа))) - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.70
asotel
2 / 2 / 0
Регистрация: 11.11.2010
Сообщений: 58
19.11.2010, 02:59     сложение Элементов числа, шахматная доска, счастливые числа))) #1
Всем Доброго времени суток.

Первая программа заключается в том что с клавиатуры вводится число например 45644, нужно занести его или в масив чисел или в строку, и отуда все елементы сложить между собой, в ответе останется одно число 4+5+6+4+4=9+6+8=15+8=6+8=14=1+4=5.

Вторая программа может у когото есть готовый исходник:
Даны обозначения двух полей шахматной доски, на которых стоят конь и пешка. Найти минимальное количество ходов, за которые конь доберется до пешки, если последняя стоит на месте. Координаты коня и пешки задаются как натуральные числа, от левого нижнего угла шахматной доски.

Третье задание:
Сколько различных ожерелий можно составить из 2-ух белых, 2-ух синих и 2-ух красных бусин. Напечатать возможные варианты и их кол-во.
Вывести список шестизначных "счастливых" чисел (сумма первых трёх цифр равна сумме трёх последних), кратных семи в 10 колонок
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.11.2010, 02:59     сложение Элементов числа, шахматная доска, счастливые числа)))
Посмотрите здесь:

Шахматная доска C++
шахматная доска C++
C++ шахматная доска
Шахматная доска C++
C++ Шахматная доска
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
19.11.2010, 03:30     сложение Элементов числа, шахматная доска, счастливые числа))) #2
Вот так первую можно без массивов решить:

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
#include <iostream>
 
int main()
{
    int num = 0;
    int sum = 11;
 
    std::cout << "Enter number: ";
    
    while (true)
    {
        char c = std::cin.get();
 
        if (c < '0' || c > '9')
            break;
        else
            num += c - '0';
    }
 
    while (sum % 10 != sum && sum != 10)
    {
        sum = 0;
 
        while (num != 0)
        {
            sum += num % 10;
            num /= 10;
        }
    }
 
    if (sum == 10)
        sum = 1;
 
    std::cout << "Sum = " << sum << std::endl;
 
    std::cin.get();
    return 0;
}
asotel
2 / 2 / 0
Регистрация: 11.11.2010
Сообщений: 58
19.11.2010, 03:37  [ТС]     сложение Элементов числа, шахматная доска, счастливые числа))) #3
Цитата Сообщение от silent_1991 Посмотреть сообщение
Вот так первую можно без массивов решить:

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
#include <iostream>
 
int main()
{
    int num = 0;
    int sum = 11;
 
    std::cout << "Enter number: ";
    
    while (true)
    {
        char c = std::cin.get();
 
        if (c < '0' || c > '9')
            break;
        else
            num += c - '0';
    }
 
    while (sum % 10 != sum && sum != 10)
    {
        sum = 0;
 
        while (num != 0)
        {
            sum += num % 10;
            num /= 10;
        }
    }
 
    if (sum == 10)
        sum = 1;
 
    std::cout << "Sum = " << sum << std::endl;
 
    std::cin.get();
    return 0;
}
можна пояснение к строкам?
как я понял
std::cout << "Enter number: "; вывод сообшения

while (true) цыкл
{
char c = std::cin.get(); вод числа

if (c < '0' || c > '9') если число не в диапазоне 0-9
break; тогда прервать

а мне нужно водится большое число прога сумирует все элементы числа между собой и оставляет одно число в диапазоне от 0 до 9
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
19.11.2010, 03:45     сложение Элементов числа, шахматная доска, счастливые числа))) #4
Чуток поправил:

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
#include <iostream>
 
int main()
{
    int num = 0;
    int sum = 11;
 
    std::cout << "Enter number: ";
    
    while (true)
    {
        char c = std::cin.get();
 
        if (c < '0' || c > '9')
            break;
        else
            num += c - '0';
    }
 
    while (sum % 10 != sum && sum != 10)
    {
        sum = 0;
 
        while (num != 0)
        {
            sum += num % 10;
            num /= 10;
        }
 
        num = sum;
    }
 
    if (sum == 10)
        sum = 1;
 
    std::cout << "Sum = " << sum << std::endl;
 
    std::cin.get();
    return 0;
}
Добавлено через 4 минуты
Программа это и делает. Фишка в том, что мы исходное число не храним, а начинаем преобразования сразу с суммы его цифр, поскольку в первом цикле происходит посимвольное считывание числа и формирование начальной суммы его цифр. Затем, в цикле, формируем сумму цифр полученного числа, запоминаем полученную сумму. Затем проверяем, что полученная сумма состоит из одной цифры либо равна 10, если это не так то в качестве числа используем эту сумму и опять находим сумму его цифр. Цикл закончится, когда сумма будет состоять из одной цифры.
asotel
2 / 2 / 0
Регистрация: 11.11.2010
Сообщений: 58
19.11.2010, 04:14  [ТС]     сложение Элементов числа, шахматная доска, счастливые числа))) #5
Цитата Сообщение от silent_1991 Посмотреть сообщение
Чуток поправил:

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
#include <iostream>
 
int main()
{
    int num = 0;
    int sum = 11;
 
    std::cout << "Enter number: ";
    
    while (true)
    {
        char c = std::cin.get();
 
        if (c < '0' || c > '9')
            break;
        else
            num += c - '0';
    }
 
    while (sum % 10 != sum && sum != 10)
    {
        sum = 0;
 
        while (num != 0)
        {
            sum += num % 10;
            num /= 10;
        }
 
        num = sum;
    }
 
    if (sum == 10)
        sum = 1;
 
    std::cout << "Sum = " << sum << std::endl;
 
    std::cin.get();
    return 0;
}
Добавлено через 4 минуты
Программа это и делает. Фишка в том, что мы исходное число не храним, а начинаем преобразования сразу с суммы его цифр, поскольку в первом цикле происходит посимвольное считывание числа и формирование начальной суммы его цифр. Затем, в цикле, формируем сумму цифр полученного числа, запоминаем полученную сумму. Затем проверяем, что полученная сумма состоит из одной цифры либо равна 10, если это не так то в качестве числа используем эту сумму и опять находим сумму его цифр. Цикл закончится, когда сумма будет состоять из одной цифры.

в коде ошибок нету, но при запуске проги она грузит проц на 50 процентов, я с ходил покурить она так ничего мне и не вывела

Добавлено через 22 минуты
все я разобрался Огромное Спасибо.
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
19.11.2010, 04:24     сложение Элементов числа, шахматная доска, счастливые числа))) #6
Можно куда проще сделать.

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
#include <iostream>
 
int main()
{
    int sum = 0;
 
    std::cout << "Enter number: ";
    
    while (true)
    {
        char c = std::cin.get();
 
        if (c < '0' || c > '9')
            break;
        else
        {
            sum += c - '0';
 
            if (sum % 10 != sum)
                sum = sum / 10 + sum % 10;
        }
    }
 
    std::cout << "Sum = " << sum << std::endl;
 
    std::cin.get();
    return 0;
}
Yandex
Объявления
19.11.2010, 04:24     сложение Элементов числа, шахматная доска, счастливые числа)))
Ответ Создать тему
Опции темы

Текущее время: 06:10. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru