C ++ fstream в >> исполнении variableName

0

Вот мой код, не знаю, почему нет ошибки, но ничего не возвращает. это нормально, если в ReadFile нет функции getline? А при отладке другая потенциальная проблема заключается в том, нужна ли карта для определения размера при объявлении карты. Я начинающий. любая помощь приветствуется.

#include <iostream>
#include <fstream>
#include<map>
#include<set>
#include<string>    

void swap(char &ch1, char &ch2){ //swap the content
    char tmp=ch1;
    ch1=ch2;
    ch2=tmp;
}

std::string ToLower(std::string s){
    for(int i=0;i < s.length();i++)
    {
        if(s[i]<='Z' && s[i]>='A')
        {
            s[i]-='A'-'a';
        }
    }
    return s;
}

std::string signature(std::string s)
{
    s=ToLower(s);
    for(int i=0;i<s.length();i++)
    {   int minIndex=i;

        for(int j=i+1;j<s.length();j++)
            if(s[j]<s[minIndex]) minIndex=j;
        swap(s[minIndex],s[i]);
    }
    return s;
}

void ReadFile(std::ifstream &in, std::map<std::string,std::set<std::string>> &m)
{
    while(true)
    {
        std::string word;
        in>>word;
        if(!in.good())break;
        m[signature(word)].insert(word);
    }
}
typedef std::map<std::string, std::set<std::string>>::const_iterator MapIterator;
 typedef std::set<std::string>::const_iterator SetIterator;

int main(){
    std::ifstream in("ospd.txt");
    std::map<std::string, std::set<std::string>> m;
    ReadFile(in,m);     


for (MapIterator iter = m.begin(); iter != m.end(); iter++)
{
    std::cout << "Key: " << iter->first << std::endl << "Values:" << std::endl;

    for (SetIterator set_iter = iter->second.begin(); set_iter != iter->second.end(); set_iter++)
        std::cout << " " << *set_iter <<std:: endl;
}

    system("pause");
return 0;}

Обновлено: программирование работает. Спасибо всем!

Теги:
fstream

1 ответ

0

Можете ли вы попробовать это.

#include <iterator>
using namespace std;


void ReadFile(std::ifstream &in, std::map<std::string,std::set<std::string>> &m)
    istream_iterator<string> itr(in);
    istream_iterator<string> end;
    while(itr != end)
    {
        string work = *itr;
        m[signature(word)].insert(word);
        ++itr;
    }
  • 0
    Вы задаете вопрос или отвечаете на вопрос? Если вы делаете первое, вы должны рассмотреть возможность размещения в качестве комментария.
  • 0
    К сожалению, это не работает. Но мне нужно добавить заголовок итератора. Спасибо @VishalKumar
Показать ещё 2 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню