【20200602程序设计思维与实践 Week15 作业】


B - ZJM 与生日礼物

题意

ZJM收到了Q老师送来的生日礼物,但是被 Q老师加密了。只有 ZJM 能够回答对Q老师的问题,Q老师才会把密码告诉 ZJM。

Q老师给了ZJM一些仅有 01组成的二进制编码串, 他问ZJM:是否存在一个串是另一个串的前缀.


思路

本题使用字典树。在基本字典树的基础上修改插入操作,使其在插入过程中检查是否访问到某一字符串的尾或插入的字符串是已存在字符串的前缀:只要有如此两种情况,则存在一个串是另一个串的前缀。


代码

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

struct Trie{
   
	static const int N=1010,charset=2;
	int tot,root,child[N][charset],flag[N];
	Trie(){
   
		memset(child,-1,sizeof child);
		root=tot=0;
	}
	void clear(){
   
		memset(child,-1,sizeof child);
		root=tot=0; 
	}
	
	int insert(char* str){
   
		
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值