【周全考虑】CodeForces 245B——Internet Address

本文详细探讨了在特定条件下生成合法网址的算法实现,重点解决了网址中'ru'前不应存在字符的问题,并针对HTTP和FTP两种协议进行了区分处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

来源:点击打开链接

看上去很简单的一道题,可是错的次数却不少。

题目要求是将一串字母转化成网址——形如格式http(ftp)://xxx.ru/xxxx的样子,看上去很简单,可是还是很容易出错。

刚开始找的时候是按照寻找第一组http/ftp,然后寻找第一个ru,构成网址,但是报错了,反例如下:httpruc

所以不能寻找第一个网址,也就是说尽量避免.ru之前没有东西,这样是不合法 的。然后注意http是四个字符,ftp只有三个字符,所以不能固定。。

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

int main()
{
	string tar,res;
	string tarstack;
	int propos=0,ctpos=0;
	cin>>tar;
	if(tar[0]=='h')
	{
		tarstack="http";
	}
	if(tar[0]=='f')
	{
		tarstack="ftp";
	}
	ctpos=tar.find("ru",tarstack.length()+1);  //5是不行的,惯性思维不可 
	if(tar[0]=='h')
	{
		cout<<tarstack<<"://";
		for(int i=4;i<ctpos;i++)
		{
			cout<<tar[i];
		}
		cout<<".ru";
		if(ctpos+2==tar.length())
			cout<<endl;
		else
		{
			cout<<"/";
			for(int i=ctpos+2;i<tar.length();i++)
			{
				cout<<tar[i];
			}
			cout<<endl;
		}
		
	}
	else if(tar[0]=='f')
	{
		cout<<tarstack<<"://";
		for(int i=3;i<ctpos;i++)
		{
			cout<<tar[i];
		}
		cout<<".ru";
		if(ctpos+2==tar.length())
			cout<<endl;
		else
		{
			cout<<"/";
			for(int i=ctpos+2;i<tar.length();i++)
			{
				cout<<tar[i];
			}
			cout<<endl;
		}
	}
	return 0;
	
}
//范例:httpruhhphhhpuhruruhhpruhhphruhhru 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值