pku 3753 根据关键字进行字符串拷贝 解题报告

 

根据关键字进行字符串拷贝
Time Limit: 1000MS   Memory Limit: 65536K
Total Submissions: 3044   Accepted: 584

Description

把源字符串拷贝到目的字符串,如果指定关键字,则以该关键字结束(不包括关键字本身),如果拷贝失败,则得到空串。 
具体要求:实现如下函数原型SafeStrcpy2KeyWord(),并在代码中调用该函数实现上述功能。该函数的实现要考虑各种可能的参数取值,以确保程序不出现崩溃。 
 
int SafeStrcpy2KeyWord(char* pDestBuffer, //拷贝的目的地地址
char* pSourceString, //拷贝的源地址
int nDestBufferSize, //拷贝的目的地缓冲区长度
char* szKeyWord); //指定关键字符串

返回值:所拷贝的字符串长度。如果拷贝失败,则返回0。

Input

输入包含多组数据,以EOF结束 
每组数据第一行为不含空格的源字符串,长度小于256;接下来的一行或多行都是关键字串(长度小于16),一直到END结束。“NULL”表示关键字串为空,此时输出的拷贝后的长度应为0,拷贝后的字符串为空串(也用”NULL”表示,见下文)。

Output

对于每组数据输出拷贝的长度和拷贝后的目的字符串,以空格分隔。如果该目的字符串为空,则用”NULL”表示。

Sample Input

/home/tony/work_server/1/rtest/relayer.out
/
/t
/1/r
.
NULL
END

Sample Output

0 NULL
5 /home
22 /home/tony/work_server
38 /home/tony/work_server/1/rtest/relayer
0 NULL
 
 
/**
  http://162.105.81.212/JudgeOnline/problem?id=3753
*/

/**
  解题思路:这题真的很BT,也很无聊,居然key为空行输出原来的源,匹配不到也是
*/

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

void safeStrcpy(string src, string key)
{
	string dest = src;
	if (key.length() == 0) {
		cout << src.length() << ' ' << src << endl;
		return ;
	}
	if(key == "NULL") {
		dest = "";
	} else {
		string::size_type pos = src.find(key);
		if(pos == -1)
			dest = src;
		else
			dest = src.substr(0, pos);
	}
	if (dest.length() == 0)
		cout << "0 NULL" << endl;
	else 
		cout << dest.length() << ' ' << dest << endl;
}

int main()
{
//	freopen("3753.in", "r", stdin);
	string src, key;
	char str[500];
	while(gets(str)) {
		src = string(str);
		while(getline(cin,key)) {
			//key = string(str);
			if (key == "END")
				break;
			safeStrcpy(src, key);
		}
	}
	return 0;
} 

 

你可能感兴趣的:(pku 3753 根据关键字进行字符串拷贝 解题报告)