Я хочу написать C ++ (C, если это обеспечивает простое решение моей проблемы) программу, в которую можно вводить, пока он не решит подать сигнал конец ввода нажатием такой комбинации кнопок, как Ctrl + D. У меня есть два вопроса по этому поводу.
Каким должен быть логический код в моем while()
цикл, чтобы обработать соответственно, когда кто-то нажимает комбинацию клавиш, как ответили в 1?
map<int,string>info;
string name;
int age;
cin>>name;
while( ????????? ){ //Input till EOF , missing logic
cin>>age;
info.insert( pair<int,string>(age,name) );
cin>>name;
}
//sorted o/p in reverse order
map<int,string> :: iterator i;
for(i=info.end(); i !=info.begin(); i--)
cout<<(*i).second<<endl;
cout<<(*i).second<<endl;
}
Программа продолжается после получения конца входного сигнала от терминала.
я использую gcc/g++ (Ubuntu/Linaro 4.7.3-1ubuntu1) 4.7.3
,
Условие while должно быть примерно таким:
while(the_key_combination_pressed_in_the_last_loop!=what_combination_will_exit_while)
{
cin>>age;
if(age!=what_combination_will_exit_while)
{
info.insert( pair<int,string>(age,name) );
cin>>name;
}
}
Использовать istream_iterator
Конструктор по умолчанию, который ожидает EOF
т.е. Ctrl+Z
или же F6+ENTER
на окнах
Ctrl+D
на Linux
Я бы использовал прокси-класс для вставки в карту на лету, примерно так:
#include <map>
#include <iterator>
#include <algorithm>
#include <string>
#include <functional>
#include <iostream>
template<class Pair>
class info_reader // Proxy class, for overloaded << operator
{
public:
typedef Pair pair_type;
friend std::istream& operator>>(std::istream& is, info_reader& p)
{
return is >> p.m_p.first >> p.m_p.second;
}
pair_type const& to_pair() const
{
return m_p; //Access the data member
}
private:
pair_type m_p;
};int main()
{
typedef std::map<int, std::string> info_map;
info_map info;
typedef info_reader<std::pair<int, std::string> > info_p;
// I used transform to directly read from std::cin and put into map
std::transform(
std::istream_iterator<info_p>(std::cin),
std::istream_iterator<info_p>(),
std::inserter(info, info.end()),
std::mem_fun_ref(&info_p::to_pair) //Inserter function
);
//Display map
for(info_map::iterator x=info.begin();x!=info.end();x++)
std::cout<<x->first<< " "<<x->second<<std::endl;
}