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

Задачи для тренировки и лучшего понимания - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Возможно переписать программу? http://www.cyberforum.ru/cpp/thread153534.html
Есть программа Upgrade UA.exe хочу запустить ее на windows mobile 6. Возможно ли ее переписать.
C++ scanf Пусть нужно читать из текста слова, пропуская все символы, кроме a-z и A-Z. То есть из текста Hello, world! ololo O_o получить только Hello world ololo O o Меня интересует, можно ли это сделать с помощью одной лишь только функции scanf. Она, насколько я понял, позволяет немного использовать регулярные выражения (точно не знаю, они ли это). Так вот, можно ли сделать так, чтобы к примеру... http://www.cyberforum.ru/cpp/thread153153.html
C++ Вернуть stdin в консоль
Допустим я перенаправил поток stdin/stdout в файл с помощью функции freopen. Как заставить его снова работать с консолью? Добавлено через 9 минут Нашел. #include <cstdlib> #include <stdio.h> #include <conio.h> using namespace std;
Прошу помочь.Подключение dll на неуправляемом С/С++ C++
Возникла проблема.Есть рабочая dll, необходимо подключить к CLR приложению. Подключение происходит нормально. Все функции работают нормально кроме одной(хотя dll проверял все работает в обычных Win32 приложениях).Данная функция производит загрузку из файла если файл не найден-возвращает код ошибки,т.е. все нормально.Но если файл находит(путь указан точный) то происходит ошибка исключение...
C++ Не сразу закрывающаяся программа http://www.cyberforum.ru/cpp/thread152799.html
Есть команды в терминале.. вроде telnet или sql, эти программы запускаешь и они остаются открытыми пока не дашь команду, например, quit. Во время работы программы она показывает знак приглашения новой команды ">". Как это можно осуществить в C++?
C++ Парсер на С вопшем есть файл с текстом..... в етом файле есть какие даные(мусор)...и есть дни: Понедельник,Вторник,среда......с етого файла нада вывести ети дни в порядке нахождениэ... ето походу несложная задача,но для новичка сложно.... нужно именно на С а не С++ ... я пока только думал считывать каждую строку в масив и проверять каждый елемент по буквам... подробнее

Показать сообщение отдельно
Mr.X
Эксперт С++
3049 / 1694 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
25.01.2011, 15:55
Цитата Сообщение от valeriikozlov Посмотреть сообщение
сообщаю, что Ваш код прошел бы все тесты.
Спасибо за добрые вести.
Чтобы не вычислять минимальный модуль вручную, можно еще так сделать:
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
//////////////////////////////////////////////////////////////////////////////////////
//Последняя цифра N!
//(Время: 1 сек. Память: 16 Мб Сложность: 39%)
//
//Требуется найти последнюю ненулевую цифру числа N! = 1*2*3*…*N.
//Входные данные
//
//Входной файл INPUT.TXT содержит единственное натуральное число N (N<=9999).
//Выходные данные
//
//В выходной файл OUTPUT.TXT выведите ответ на задачу.
//
//Пример
//INPUT.TXT
//1
//OUTPUT.TXT
//1
//
//Пример
//INPUT.TXT
//5
//OUTPUT.TXT
//2
//////////////////////////////////////////////////////////////////////////////////////
#include <iostream>
//////////////////////////////////////////////////////////////////////////////////////
int  get_min_mod()
{     
    for(int  val = 10;; val *= 10)
    {
        bool  cont = false;
        for(int  dig = 2; dig <= 9; ++dig)
        {
            if(   val % dig == 0
               && val / dig % 10 != 0)
            {
                cont = true;
                break;
            }
        }
        if(!cont)  return val;
    }
}
//////////////////////////////////////////////////////////////////////////////////////
int  get_last_nonzero_digit_of_factorial(int  N, int  min_mod)
{
    int last_dig = 1;
    for(int  i = 2; i <= N; ++i)
    {
        last_dig *= i;
        while(last_dig % 10 == 0)
        {
            last_dig /= 10;
        }        
        last_dig %= min_mod;
    }
    return last_dig % 10;
}
//////////////////////////////////////////////////////////////////////////////////////
int main()
{
    std::locale::global(std::locale(""));
 
    int  min_mod = get_min_mod();
    for(;;)
    {
        std::cout << "N = ";
        int N = 0;
        std::cin >> N;
        
        std::cout << "Последняя ненулевая цифра факториала "
                  << N 
                  << ": "
                  << get_last_nonzero_digit_of_factorial(N, min_mod)
                  << std::endl;
    }    
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru