C++ 从键盘读入行列不确定的字符串

本文介绍如何使用C++从标准输入读取不定数量的行和列的字符串,并将其存储到二维vector中。文章提供了两种实现方法,一种使用getline结合istringstream处理每一行,另一种则直接使用cin读取。

C++ 从键盘读入行列不确定的字符串,并以空格为间隔将每个字符串保存进二维的vector

#include <string>
#include <iostream>
#include <vector>
#include<sstream>
using namespace std;

int main()
{
	vector<vector<string>> c1;
	string s;
	string word;
	int n;
	cin >> n;
	for (int i = 0; i < n; i++) {
		vector<string> c2;
		while (getline(cin, s, ' ')) {
			stringstream ss(s);
			while (ss >> word)
				c2.push_back(word);
		}
		/*for (const auto& p : c2) {
			cout << p << endl;*/
		c1.push_back(c2);
		//}
		cin.clear();
	}
}

n为输入的行数,列数可以是未知的。

while (getline(cin, s, ' ')) //读取一行,遇到空格就结束,但是‘\n’会包含进字符串里面,输入ctrl+Z结束一次循环
使用stringstream进行单个字符串的提取,这里是用来去掉换行符,包含头文件<sstream>。

昨天一直被那个换行符不能当做完成一次输入,研究了很久弄晕了,其实有更简洁的直接用cin就好了<pre name="code" class="cpp"><pre name="code" class="cpp">int main()
{
	vector<vector<string>> c1;
	string s;
	string word;
	int n;
	cin >> n;
	for (int i = 0; i < n; i++) {
		vector<string> c2;
		while (cin >> s) {
			c2.push_back(s);
		}
		c1.push_back(c2);
		cin.clear();
		}
}






但是这样还是同样的trick,一定要输入ctrl+Z才能结束一次输入,假如我需要多次输入数据,输入换行符就表示这次输入完成,进入下一次我该怎么做,有好的意见的欢迎留言~~~


### 多字符串结束标志的检测 在编程语言中,尤其是像C/C++这样的低级语言里,多字符串通常通过特定条件来标记其结束。对于不同的应用场景,可以选择不同类型的结束标志。 #### 使用预定义关键字作为结束符 一种常见的方式是在输入过程中遇到某个特殊单词或短语时停止接收新。例如,在给定的例子中,“end”被用来指示不再继续接受新的字符串输入[^2]: ```cpp #include <iostream> #include <cstring> using namespace std; int main(){ char strs[10][80]; int line = 0; while (line < 10 && cin.getline(strs[line], sizeof(strs[line]))) { if(strcmp(strs[line],"end")==0){ break; // 当输入为 "end" 时退出循环 } ++line; } // 反转打印已读取的内容 for (--line; line >= 0; --line) cout << strs[line] << endl; return 0; } ``` 这段代码展示了如何利用`strcmp()`函数比较当前是否等于“end”。如果相等,则执break命令中断while循环,从而完成整个过程中的多字符串收集工作。 #### 利用EOF(文件结尾) 另一种方式是依靠标准输入流达到它的终点——即到达End Of File状态。这种方式适用于从文件或其他外部源批量导入大量文本的情况。当用户交互式地运程序并希望手动触发此事件时,可以在Unix/Linux终端下按Ctrl-D组合键;而在Windows平台上则是F6或者Ctrl-Z加回车键[^3]。 ```cpp #include <iostream> #include <vector> #include <string> using namespace std; int main() { vector<string> lines; string temp; while(getline(cin, temp)) { // 不断获取直到遇到 EOF 或者其他错误发生 if(!cin || cin.eof()) break; lines.push_back(temp); } // 输出所有已经存储下来的 for(auto it = lines.rbegin(); it != lines.rend(); ++it) cout << *it << '\n'; return 0; } ``` 上述例子说明了怎样捕捉到EOF信号,并据此决定何时终止进一步的数据采集活动。此外还提供了简单的逻辑用于展示所获得的信息序列反转后的样子。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值