[C ++] - solução de intercalação para um problema de gado fora do fluxo de entrada

fluxo de entrada de intercalaçãoAqui Insert Picture Descrição

O título é simples, mas não é fácil de fazer (Eu posso ser mudo, treinou, treinou, treinou)

Idea: Porque a questão, disse entrada separados por um espaço, por isso vamos introduzir duas cordas, de acordo com a primeira divisão espaço aberto, respectivamente, no vector, então temos de prestar atenção a vários pontos:
1, corda 1 tem sido a extremidade de saída, a fim da corda 2 de saída não é
2, a extremidade da corda 2 de saída, mas não uma extremidade de saída

Aqui está o código:

#include  <iostream>
#include <stdlib.h>
#include <vector>
#include <string>
using namespace std;
vector<string> Splict(string str, string s)
{
	str += s;
	vector<string> v;

	int pos = str.find(s);
	while (pos!= string::npos)
	{
		string ret = str.substr(0, pos);
		v.push_back(ret);
		str = str.substr(pos + 1);  //str为pos+1后面的字符串
		pos = str.find(s);
	}
	return v;
}
int main()
{
	string str1;
	string str2;
	getline(cin, str1);
	getline(cin, str2);
	vector<string> v1;
	v1=Splict(str1, " ");
	vector<string> v2;
	v2 = Splict(str2, " ");
	int flag = 0;
	for (int i = 0, j = 0; i < v1.size();)
	{
		for (int k = 0; k < 4; k++)
		{
			cout << v1[i++] << " ";

			if (i >= v1.size())
			{
				flag = 1;  //说明v1已经输出完了
				break;
			}
		}
		if (j >= v2.size())  //判断v2是不是比v1先输出完成,否则会发生断错误
		{
			for (; i < v1.size();)
			{
				cout << v1[i++] << " ";
			}
			break;
		}

		if (flag)  //v1已经输出完了,判断v2是否已经输出结束
		{
			for (;j < v2.size();)
			{
				cout << v2[j++] << " ";
			}
		}
		else
			cout << v2[j++] << " ";
	}
	system("pause");
	return 0;
}
Publicado 42 artigos originais · ganhou elogios 13 · vista 1761

Acho que você gosta

Origin blog.csdn.net/Vicky_Cr/article/details/105320490
Recomendado
Clasificación