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

токены - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Упражнения http://www.cyberforum.ru/cpp-beginners/thread349308.html
Всем добрый день! Недавно начал изучать С++. Прошел Несколько тем: Классы, управляющие операторы, немножко циклы. Есть ли на форуме такая тема куда выкладывают упражнения, потому что в книжке их очень мало, а самим придумывать не получается. Если такой темы нет, то подкиньте пару задачек плиз. Спасибо!
C++ Код не работает как метод... День добрый! есть код: CoInitialize(NULL); * *if(CoInitializeSecurity( NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_PKT, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE, 0) != S_OK) * *{ * * * *qDebug() << "Error: CoInitialize"; * * * *return 1; } http://www.cyberforum.ru/cpp-beginners/thread349297.html
C++ Не получается решить задачу
Поле first — вещественное число, левая граница диапазона; поле second — вещественное число, правая граница диапазона. Реализовать метод rangecheck() — проверку заданного чис-ла на принадлежность диапазону. В принципе,я уже почти решил эту задачу, но есть некоторые проблемы. :wall: Так же хочется посмотреть другие решения:)
C++ Как правильно открыть файл и считать из него строку?
Прювет! подскажите пажалста, как правильно открыть и считать строку из файла. весь функционал по обработке уже написал, а тут застрял как внебрачный ребенок буратино >_< std::ifstream file("C:\\interface.txt"); std::string lines; if(file.is_open()){ std::string buff; while( !file.eof()){
C++ Вывести сообщение о том, что все элементы в массиве равны http://www.cyberforum.ru/cpp-beginners/thread349270.html
Здравствуйте... суть проблемы состоит в том, что я не знаю, как вывести сообщение о том, что все элементы массива равны между собой. Задача заключается в том, чтобы найти сумму элементов до минимального элемента массива, а в случае, если все элементы равны, то есть все минимальные (например только нули или только единицы) - вывести сообщение об этом. А так же если минимальный элемент стоит...
C++ __declspec(property) и с чем его едят Что это такое и как это использовать? У меня задание в лабораторной по обычному с++, но вот такая штука имеет место быть. Насколько я понял это какие-то свойства, прикрученные ms но как они используются? Заголовочный файл где они есть (сама программа представляет собой структуру по хранению данных о студентах): //#include "stdafx.h" #ifndef TYPES_INCLUDE #define TYPES_INCLUDE ... подробнее

Показать сообщение отдельно
Mr.X
Эксперт С++
 Аватар для Mr.X
2799 / 1575 / 246
Регистрация: 03.05.2010
Сообщений: 3,657
09.09.2011, 17:38     токены
Цитата Сообщение от jambas92 Посмотреть сообщение
Mr.X, первое решение абсолютно верно, но тест не проходит из за того что n может доходить до 1 <= n <= 10^100).
В первом сообщении у вас было написано 10100, что и ввело всех в заблуждение.
Тогда так:
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
78
79
80
81
82
83
84
85
86
87
88
89
90
/////////////////////////////////////////////////////////////////////////////////////////
// Однажды Азиз заметил, что номер его телефона 321321 и номер его дома 111 обладают 
// интересным свойством: их можно разбить на несколько одинаковых частей: 321|321, 1|1|1. 
// Азиз назвал числа, которые можно разбить на k частей (k > 1), k-числами. Например, 
// число 2323 является 2-числом (23|23), число 101010 — 3-числом (10|10|10), а число 222222 
// является од- новременно 2-числом (222|222), 3-числом (22|22|22) и 6-числом (2|2|2|2|2|2). 
// Васе интересно, много ли на свете таких интересных чисел, поэтому он просит вас написать 
// программу, находящую количество k-чисел, не превосходящих заданное число n.
//
// Формат входных данных:
// На первой строке стандартного потока ввода задано число k, 
// на второй — число n (2 <= k <= 100, 1 <= n <= 10^100).
//
// Формат выходных данных:
// Первая строка стандартного потока вывода должна содержать одно число — количество k-чисел, 
// не превышающих n.
//
// Вход: 2 3140
// Выход: 31 
/////////////////////////////////////////////////////////////////////////////////////////
#include <algorithm>
#include <iostream>
#include <string>
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::string       T_str;
typedef T_str::size_type  T_pos;
/////////////////////////////////////////////////////////////////////////////////////////
T_str  count_k_numbers_not_great_n
    (
        int           k,
        const T_str&  n_str
    )
{
    int    n_len       = n_str.size();
    int    res_len     = n_len / k;
    if(res_len == 0) return "0";
    int    head_len    = res_len + n_len % k;
    T_str  n_str_head  = n_str.substr(0, head_len);
    T_str  res         = T_str(res_len, '9');
    if(res_len == head_len)
    {
        res = n_str_head;
        T_str  max_val_str;
        for(int  i = 0; i < k; ++i)
        {
            max_val_str += res;
        }
        if(max_val_str > n_str)
        {
            for(size_t  res_pos = res_len - 1; ; --res_pos)
            {
                if(res[res_pos] > '0')
                {
                    --res[res_pos];
                    break;
                }
                else
                {
                    res[res_pos] = '9';
                }
            }
        }
    }
    if(res[0] == '0')
    {
        res.erase(0, 1);
    }
 
    return  res;
}
/////////////////////////////////////////////////////////////////////////////////////////
int main()
{
    std::locale::global(std::locale(""));
    std::cout << "k = ";
    int  k = 0;
    std::cin >> k;
 
    std::cout << "n = ";
    T_str  n;
    std::cin >> n;
    std::cout << "Количество "
              << k
              << "-чисел, не превосходящих "
              << n
              << ", равно "
              << count_k_numbers_not_great_n(k, n)
              << "."
              << std::endl;
}
 
Текущее время: 15:05. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru