C++输入困难
C++ input difficulty
我正在尝试解决ACM Timus的以下问题:http://acm.timus.ru/problem.aspx?space=1&num=1242,但我不知道如何正确读取输入。我正在使用两个while循环。一旦在输入中写入字符串,第一个就会终止,但第二个之后就不起作用了。这是我的代码:
#include <iostream>
#include <vector>
using namespace std;
struct Pair
{
void AddParent(int a)
{ parents.push_back(a); }
void AddChild(int a)
{ children.push_back(a);}
vector<int> parents;
vector<int> children;
};
vector<bool> visited;
vector<Pair> graph;
void DFS1(int n)
{
visited[n] = true;
for(int i = 0 ; i < graph[n].parents.size() ; i++)
{
int t = graph[n].parents[i];
if(!visited[t])
DFS1(t);
}
return;
}
void DFS2(int n)
{
visited[n] = true;
for(int i = 0 ; i < graph[n].children.size() ; i++)
{
int t = graph[n].children[i];
if(!visited[t])
DFS2(t);
}
return;
}
int main()
{
int n;
cin >> n;
graph.resize(n);
visited.resize(n);
int a,b,c;
vector<int> victim;
////////////////////////////////
while(cin >> a && cin >> b)
{ a--;b--;
graph[a].AddParent(b);
graph[b].AddChild(a);
}
cin.clear();
cin.ignore();
while(cin >> c)
{
victim.push_back(c);
}
////////////////////////////////
for(int i = 0 ; i < victim.size() ; i++)
if(!visited[victim[i]]){
DFS1(victim[i]);
DFS2(victim[i]);
}
bool vis = false;
for(int i = 0 ; i < n ; i++)
if(!visited[i])
{
vis = true;
cout << i + 1 << " ";
}
if(!vis)
cout << 0;
return 0;
}
在进入第二个 while 循环之前,您应该清除输入流 cin。
while(cin >> a && cin >> b)
{ a--;b--;
graph[a].AddParent(b);
graph[b].AddChild(a);
}
cin.clear();
cin.ignore(std::numeric_limits<std::streamsize>::max(), 'n');
while(cin >> c)
{
victim.push_back(c);
}
并包括标头限制
为什么我们在读取输入后调用 cin.clear() 和 cin.ignore()?
相关文章:
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 2D数组来自文本输入,中间有空格
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 检查输入是否不是整数或数字
- 正在尝试了解输入验证循环
- 读取文件并输入到矢量中
- C++如何通过用户输入删除列表元素
- 用c++从输入文件中读取另一行
- 读取文件的最后一行并输入到链接列表时出错
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何使用用户输入在C++中正确填充2D数组
- C++MySQL C api用户输入行
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- 用户定义函数中的指针和输入
- 如何在C++中检查2D数组中负值的输入验证
- 如何只允许用户输入正整数
- 在while循环中输入带有std::cin的字符串后,控制台会输出大量胡言乱语
- 输入中的字符串数未知(以字母表示)
- cpp二进制搜索问题,计算给定数组中输入元素的出现次数
- 在一个模板函数中,若输入的类型是enum类,我该如何使用std::underlying_type