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

STL mismatch - C++

Восстановить пароль Регистрация
 
borovik
208 / 202 / 1
Регистрация: 25.07.2010
Сообщений: 1,131
19.12.2010, 23:24     STL mismatch #1
чтото я запутался в синтаксисе помогите
заюзать mismatch, элементы не равны если различие более чем на Х.
пс. если возможно организовать без pair?
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
#include "stdafx.h"
#include <iostream>
#include <string>
#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[])
{
    mycl cl;
    string a,s;
    string::iterator it;
    pair<string*,string*>difpos(0,0);
    cin>>cl.x;
    cin>>a;
    cin>>s;
    difpos = mismatch(a,a.length(),s,cl);
            it = difpos.first;
    if (!a.end())
         cout<<"не совпадает на более чем Х"<<*it;
        else {
             cout<<"все элементы совпадают по правилу Х!";
         }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.12.2010, 23:24     STL mismatch
Посмотрите здесь:

Почему выскакивает Warning "signed/unsigned mismatch"? C++
STL C++
C++ STL
C++ STL
C++ STL.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
19.12.2010, 23:43     STL mismatch #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
#include "stdafx.h"
#include <iostream>
#include <string>
#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[])
{
        mycl cl;
        string a,s;
        pair<string::iterator, string::iterator> My;
        cin>>cl.x;
        cin>>a;
        cin>>s;
        My=mismatch(a.begin(), a.end(), s.begin(), cl);
        string::iterator it=My.first;
        if (it != a.end())
             cout<<"не совпадает на более чем Х"<<*it;
        else {
             cout<<"все элементы совпадают по правилу Х!";
         }
}
borovik
208 / 202 / 1
Регистрация: 25.07.2010
Сообщений: 1,131
20.12.2010, 00:03  [ТС]     STL mismatch #3
так с синтаксисом разобрался (не понимаю как ты его так хорошо знаешь )
чёт в return !(z-c)<x; напутано с x=2 а=9 с=3 - выдает все гуд, хотя разница а и с превышается на 2
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
20.12.2010, 00:34     STL mismatch #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
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";
}
borovik
208 / 202 / 1
Регистрация: 25.07.2010
Сообщений: 1,131
20.12.2010, 17:31  [ТС]     STL mismatch #5
да так и нужно было )
Yandex
Объявления
20.12.2010, 17:31     STL mismatch
Ответ Создать тему
Опции темы

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