我正在尝试通过在线解决一些问题来学习动态编程。我遇到的一个问题需要处理以下输入
4 10 3 4 4 5 6 7 5 7
第一个指向项目数量,第二个是总容量,其余四个(成对)现在应该指向价值和容量。
我遇到的问题是解析它的代码。
#include<iostream>
#include<map>
#include<iterator>
using namespace std;
template<typename T>
void print(typename T::const_iterator start,
typename T::const_iterator end)
{
typename T::const_iterator itr=start;
while(itr!=end)
{
std::cout << itr->first << " " << itr->second << std::endl;
itr++;
}
}
int main()
{
int _M_N; // total numbers
int _M_V; // total values
std::map<int,int> _M_Values;
istream_iterator<int> isi(cin);
_M_N = *isi;
_M_V = *++isi;
for(int i=0;i<_M_N;i++)
{
//int m=*++isi,n=*++isi;
//_M_Values.insert(make_pair(m,n));
_M_Values.insert(make_pair(*++isi,*++isi));
}
print<std::map<int,int> >(_M_Values.begin(),_M_Values.end());
}
当我运行这个程序时,我得到了这个输入的错误输出
akhetarp@desktop> knapsack < test
4 3
5 4
7 6
但是,如果我取消注释该行并注释较早的行以进行插入,我会得到预期的
int m=*++isi,n=*++isi;
_M_Values.insert(make_pair(m,n));
// _M_Values.insert(make_pair(*++isi,*++isi));
3 4
4 5
6 7
5 7
我知道这一定是一些基本错误。提前致谢,