( ̄y▽ ̄)~ 智能手机II

TimeLimit: 3000/1000 MS (Java/Others)  MenoryLimit: 32768/32768 K (Java/Others)
64-bit integer IO format:%I64d
Problem Description
在我们的手机通讯录中,我们可以通过输入手机号码时,搜索都联系人。如果当我们输入的手机号码正好也是另外一个手机号码的部分前缀时,同样会显示,前缀为这个手机号码的人的信息。只有当你输入的号码是唯一的,也就是输入的号码不是其他号码的前缀,,才会唯一的显示一个人的信息。 
比如: 
1. LhBoy 911 
2. bobo 10086 
3. hzz 10010 
当你输入其中任何一个人的号码时,都只会唯一的显示一个人的信息的、 
如果这个通讯录多增加一组:4. Orz 1001011 ,则,当你输入10010的时候,所查找到的联系人有hzz和Orz。 
现在问题来了,给你一个通讯录,问你在通过手机号码查询时,所查询出来的联系人的信息是否唯一,唯一的话输出YES,否则输出NO。 
*内存超限的话,就尝试着释放内存把( ̄y▽ ̄)~~
Input
第一行输入一个整数T,表示有T(1 <= t <= 40)组测试案例。 
每一组测试案例先输入一个整数N( 1 <= n <= 10000),表示通讯录有N条信息。 
接下来有N行,每一行表示各个联系人的电话号码,每一个电话号码最多10位数。
Output
For each test case, output “YES” if the list is consistent, or “NO” otherwise.
SampleInput
2
3
811
87625999
81125426
5
113
12340
123440
10086
98346
SampleOutput
NO
YES 解法:
大同小异,用字典树做,如果用的是链式的字典树还需要释放内存空间,用数组形式的字典数就不需要、
代码:
 #include <stdio.h>
#include <stdlib.h>
#include <string.h> using namespace std;
typedef struct Trie
{
struct Trie*Node[];
int num;
}Trie_Node;
Trie_Node*Head; Trie_Node* New_Node()
{
Trie_Node*H;
int i;
H=(Trie_Node*)malloc(sizeof(Trie_Node));
for(i=;i<=;i++)
H->Node[i]=NULL;
H->num=;
return H;
} void Free(Trie_Node* a)
{
if(a==NULL) return ; //释放内存
else
{
for(int i=;i<;i++)
Free(a->Node[i]);
}
free(a);
}
int Insert_Trie(char STR[])
{
Trie_Node *t;
Trie_Node *h=Head;
int i,Len=strlen(STR),SIGN,j=;
for(i=;i<Len;i++)
{
SIGN=STR[i]-'';
if(h->Node[SIGN]==NULL)
{
t=New_Node();
h->Node[SIGN]=t;
j=;
}
h=h->Node[SIGN];
if(h->num){j=;break;}
if(i==Len-)h->num=;
}
return j;
}
int main()
{
int T,N,i,j,SIGN;
char STR[];
scanf("%d",&T);
while(T--)
{
Head=New_Node();
scanf("%d",&N);
SIGN=;
for(i=;i<N;i++)
{
scanf(" %s",STR);
j=Insert_Trie(STR);
if(j==)SIGN=;
}
if(SIGN)printf("NO\n");
else printf("YES\n");
Free(Head);
}
return ;
}
 

( ̄y▽ ̄)~ 智能手机II的更多相关文章

  1. (╭ ̄3 ̄)╭ 小希的迷宫II

    (╭ ̄3 ̄)╭ 小希的迷宫II TimeLimit: 2000/1000 MS (Java/Others)  MenoryLimit: 65536/32768 K (Java/Others) 64-b ...

  2. ACM数论之旅16---母函数(又名生成函数)(痛并快乐着(╭ ̄3 ̄)╭)

    (前排出售零食瓜子) 前言: 母函数是个很难的东西,难在数学 而ACM中所用的母函数只是母函数的基础 应该说除了不好理解外,其他都是非常简单的 母函数即生成函数,是组合数学中尤其是计数方面的一个重要理 ...

  3. (暂时弃坑)(半成品)ACM数论之旅18---反演定理 第二回 Mobius反演(莫比乌斯反演)((づ ̄3 ̄)づ天才第一步,雀。。。。)

    莫比乌斯反演也是反演定理的一种 既然我们已经学了二项式反演定理 那莫比乌斯反演定理与二项式反演定理一样,不求甚解,只求会用 莫比乌斯反演长下面这个样子(=・ω・=) d|n,表示n能够整除d,也就是d ...

  4. [luoguP1010] 幂次方 ^(* ̄(oo) ̄)^

    传送门 递归.. 代码 #include <cstdio> int n; int bit[15]; inline void solve(int x) { int i, f = 0; if( ...

  5. 樱花漫地集于我心,蝶舞纷飞祈愿相随---总结 顕出:void-sampling 显示:void-sampling

    知识点: 分支语句,四则运算,( ̄y▽ ̄)~* 实验过程中遇到的问题及解决方法: 忘记换行,忘记代码,输入法切换(´∀`*) 暂时还得照书写,*★,°*:.☆\( ̄▽ ̄)/$:*.°★* 实验心得体会 ...

  6. 樱花漫地集于我心,蝶舞纷飞祈愿相随---总结 适者:survival of the fittest 适者:survival of the fittest

    编程什么的最讨厌了,总是忘记一些乱七八糟的,看起来并没有什么乱用的,比如(::“<>{}, 还有交作业的时候总是忽略大小写<(▰˘◡˘▰)> 马马虎虎莫名其妙就错了,其实大小写 ...

  7. 樱花漫地集于我心,蝶舞纷飞祈愿相随 発生:genesis 发生:genesis

    朱念齐,学号160809404(这些其实并没有什么乱用)唉( ̄y▽ ̄)~* 正文 鬼族后裔,原是露格尼卡王国的子民,在王立比布利亚学园任职魔法使拥有分别为: 拥有书库: 书库:傲慢(Superbia) ...

  8. 当前主流的安卓APP开发IDE

    什么是主流的开发安卓APP的方式? 我是去年4月份接触的Android开发,因此特别有感触,可以明显的感受到安卓APP主流开发方式的改变. 去年,2015年年初,各大安卓开发群大部分大牛在用Eclip ...

  9. Visual Studio 当前不会命中断点的问题

    这个问题一般有两个版本 1.当前不会命中断点,还没有为该文档加载任何符号. 2.当前不会命中断点,源代码与原始版本不同. 要解决第一个问题,就要了解一种文件格式“PDB(Program DataBas ...

随机推荐

  1. jquery验证表单是否满足正则表达式是否通过验证例子

    //验证通用函数 a表示元素对象,b表示正则表达式,c存bool值 function testyz(a,b,c){ c=false; $(a).on("blur",function ...

  2. CodeForces 670D Magic Powder

    二分. 二分一下答案,然后验证一下. #pragma comment(linker, "/STACK:1024000000,1024000000") #include<cst ...

  3. iOS SDWebImage的使用

    现在把代码贴出来,供大家参考.尤其是新手,看完这篇博客,图片缓存so easy.最后有demo供大家下载,先学习. 第一步,下载SDWebImage,导入工程.github托管地址https://gi ...

  4. html和html5学习

    html和html5学习 chorme.safari中的input或textarea html超链接(a)详细讲解 html5新增及删除标签 html表格 图片加alt属性 input的type属性 ...

  5. swift 2 选择头像图片

    一句话选择单个头像图片 新建ImagePickerViewController类: /* let imagePicker = ImagePickerViewController() imagePick ...

  6. Python基础(十)-模块

    模块初识 一般把不同功能代码放到不同py文件,一个py文件就是一个模块 三种模块库: 1.Python标准库 2.第三方库 3.自定义库 导入模块:import 库名 (Python解释器只认识执行文 ...

  7. C#拾遗(二、函数)

    1. 参数数组.C#的特色,允许函数参数的最后指定一个参数数组,可以使用个数不定的参数调用,用params关键字定义 static double SumVals(params double[] val ...

  8. Mac下MySQL的安装与配置

    之前一直用的是阿里云的服务器,在服务器上装了一个MySQL,但是今天发现到期了,而且续费时发现之前的大学生优惠不能用了,可是明明到6月份,大学生才毕业啊,shit!!!所以没办法只能在自己电脑上装一个 ...

  9. OBIEE 12C

    OBIEE 12C安装配置 oracle官网下载BIEE12C 在虚拟机上安装 linux 在SQLPLUS启动和停止Oracle数据库 重启oracle数据库 cmd->1.lsnrctl s ...

  10. webuploader问题

    pick里面的id,我理解就是有点选择器的意思,目前我的认知是不设置它就无法取文件操作: 然后,查看页面的时候发现,pick通过id选定的元素,被替换成了webuploader自定义的元素,表现是-- ...