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

STL mismatch - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ функция для приближённого вычисления Log... http://www.cyberforum.ru/cpp-beginners/thread215145.html
здраствуйте! помогите с задачкой пожалуйста Написать и протестировать функцию для приближённого вычисления Log2х с помощью многочлена наилучшего приближения (ниже прилагается картинка с формулой) где а1=2,8854 а3=0,9615 а5=0,5990
C++ Правая часть окна консоли Здравствуйте, господа. От чего зависит наличие скроллера в правой части окна консольного приложения? В опр. случаях наблюдал появление скроллера в случае наличия функций system, однако так и не понял, что небходимо для этого на самом деле. Заранее благодарю за возможные ответы. http://www.cyberforum.ru/cpp-beginners/thread215144.html
C++ Как скопировать текст программы в блокнот
Я написала программу, используя Borland C++ 3.0. Подскажите, пожалуйста, как скопировать текст этой программы в блокнот (в конечном итоге мне нужно получить его в ворде).
C++ двухстороннии очереди
ребят помогите пожалуйсто, голову сломал неполучается задача... Написать функцию для создания очередей. Двухстороннюю очередь, у каждого элемента которой указатель на предыдущий и следующий. Добавление элемента с головы очереди и удаление с хвоста. Создать функцию добавления 1 элемента, удаление 1 элемента, вывод всего на экран. Добавлено через 1 час 24 минуты подскажите с чего начать, весь...
C++ Массивы http://www.cyberforum.ru/cpp-beginners/thread215119.html
Помогите пожалуйста, срочненько :(( H - сумма элементов массива с нечетными номерами E - максимальный по модулю элемент массива G - Количество отрицательных элементов массива (H+E/(H+1))*G #include <stdio.h> #include <math.h>
C++ макроподстановки=))) Необходимо написать программу, использующую макроподстановку и считающую количество пробелов во вводимой с клавиатуры текстовой строке. Не дублируйте темы. подробнее

Показать сообщение отдельно
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
20.12.2010, 00:34     STL mismatch
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
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <algorithm>
#include "TCHAR.h"
using namespace std;
 
class mycl{
        public:
                int x;
                bool operator()(int z, int c){
                        return !((z-c)<x);
                }
};
 
int _tmain(int argc, _TCHAR* argv[])
{
        locale().global(locale(""));
        const int n=5;
        mycl cl;
        std::vector<int> a;
        std::vector<int> s;
        pair<std::vector<int>::iterator, std::vector<int>::iterator> My;
        cin>>cl.x;
        std::cout<<"Enter "<< n <<" elements of first vector\n";
        for(int i=0; i<n; ++i)
        {
            int t=0;
            std::cin>>t;
            a.push_back(t);
        }
        std::cout<<"Enter "<< n <<" elements of second vector\n";
        for(int i=0; i<n; ++i)
        {
            int t=0; 
            std::cin>>t;
            s.push_back(t);
        }
        My=mismatch(a.begin(), a.end(), s.begin(), cl);
        std::vector<int>::iterator it=My.first;
        if (it != a.end())
             cout<<"не совпадает на более чем Х "<<*it<<'\n';
        else {
             cout<<"все элементы совпадают по правилу Х!";
         }
}
По-моему так логичнее... Правда как ни странно тут идет лишь 1 элемент в любом случае либо 0...

Добавлено через 10 минут
Кстати насчет mismatch. Фишка в том, что если не найдены элементы - он формирует пару из двух первых элементов. Так что я даже хз как проверить)

Добавлено через 12 минут
Вот так кажись лучше.

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
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
 
class mycl{
        public:
                int x;
                bool operator()(int z, int c){
                        return (z-c) <= x;
                }
};
 
int _tmain(int argc, _TCHAR* argv[])
{
        locale().global(locale(""));
        const int n=5;
        mycl cl;
        std::vector<int> a;
        std::vector<int> s;
        pair<std::vector<int>::iterator, std::vector<int>::iterator> My;
        cin>>cl.x;
        std::cout<<"Enter "<< n <<" elements of first vector\n";
        for(int i=0; i<n; ++i)
        {
            int t=0;
            std::cin>>t;
            a.push_back(t);
        }
        std::cout<<"Enter "<< n <<" elements of second vector\n";
        for(int i=0; i<n; ++i)
        {
            int t=0; 
            std::cin>>t;
            s.push_back(t);
        }
        My=mismatch(a.begin(), a.end(), s.begin(), cl);
        std::vector<int>::iterator it=My.first;
        std::vector<int>::iterator iter=My.second;
                if(it != a.end() && iter != s.end())
            cout<<"первые элементы, которые не совпадает на более чем "<< cl.x<<" - "<<*it<<' '<<*iter<<'\n';
                else
            cout<<"Все элементы выполняют условие\n";
}
 
Текущее время: 20:15. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru