求解:在一份文本文件中,查找其中所有的anagram。例如,如果这份文件中包含了stop、tops、pots这样三个单词,这三个词就是一组 anagram,这三个单词都是由s、t、o、p这四个字母组成的。这份文件中可能存在多组anagram,大小写视为同样字符。在解答时,需要注意代码的效率、质量。当不能给出完整代码时,可以描述解题思路。(PS:该题目取自JAVA板块,本人仅做练习用)。
下面是PHP常规思维的源码,没有用class,尽写function了。
<?php
//定义字符偏移量
$alpha=array(
array('a','A'),
array('b','B'),
array('c','C'),
array('d','D'),
array('e','E'),
array('f','F'),
array('g','G'),
array('h','H'),
array('i','I'),
array('j','J'),
array('k','K'),
array('l','L'),
array('m','M'),
array('n','N'),
array('o','O'),
array('p','P'),
array('q','Q'),
array('r','R'),
array('s','S'),
array('t','T'),
array('u','U'),
array('v','V'),
array('w','W'),
array('x','X'),
array('y','Y'),
array('z','Z'),
);
//分裂文本为串
function splitText($file=''){
$text=file_get_contents($file);
if(!$text){
return false;
}else{
$reg='/\s+|\n/';
return preg_split($reg,$text);
}
}
//获取串的第一个字符值
function firstValue($char){
global $alpha;
foreach($alpha as $key=>$set){
if(in_array($char,$set)){
return $key;
}
}
return false;
}
//计算偏移量
function calcOffset($num,$min){
return $num-$min;
}
//获取串的最小字符值,偏移量数组
function calcCond($str){
if(!$str){
return false;
}else{
global $alpha;
$length=strlen($str);
$min=firstValue(substr($str,0,1));
$sort=array();
$sort[0]=$min;
for($i=1;$i<$length;$i++){
$temp=substr($str,$i,1);
foreach($alpha as $key=>$set){
if(in_array($temp,$set)){
if($key<=$min){
$min=$key;
}
$sort[]=$key;
continue;
}
}
}
if(sort($sort)){
if(array_map('calcOffset',$sort,array_fill(0,count($sort)-1,$min))){
return array($min,$sort);
}
}
return false;
}
}
//判断anagram
function justAnagram($a,$b){
if($a===$b){
return true;
}else{
if(strlen($a)!=strlen($b)){
return false;
}else{
$rsA=calcCond($a);
$rsB=calcCond($b);
for($i=0;$i<count($rsA);$i++){
if($rsA[$i]!=$rsB[$i])
return false;
}
return true;
}
}
}
//判断文本中存在的anagram,返回数组
function findAnagrams($file='test.txt'){
$array=splitText($file);
if(!$array){
return false;
}
$rs=array();
$i=0;
while(!empty($array)){
$first=$array[0];
$rs[$i]=array($first);
$count=count($array);
$track=array(0);
for($j=1;$j<$count;$j++){
if(justAnagram($first,$array[$j])){
$rs[$i][]=$array[$j];
$track[]=$j;
continue;
}
}
$count2=count($track);
for($k=$count2-1;$k>=0;$k--){
array_splice($array,$k,1);
}
$i++;
}
return $rs;
}
print_r(findAnagrams());
?>
分享到:
相关推荐
给定两个字符串 `s` 和 `t`,编写一个函数来判断这两个字符串是否是异位词。即检查 `s` 和 `t` 是否包含完全相同的字符以及相同的字符频率,但字符出现的顺序可以不同。 #### 解决方案分析 为了解决这个问题,我们...
要在浏览器中使用,请使用 。 用法 var createHash = require ( 'compute-anagram-hash' ) ; createHash( [arr] ) 创建一个哈希表。 var hash = createHash ( ) ; 要初始化哈希表,请提供一个string array 。 ...
在“anagram:使用Javascript和jQuery的LEARN SD的Anagram项目”中,我们关注的核心是利用这两种强大的技术来实现一个字母谜题(Anagram)检测器。Anagram是两个或多个单词,它们通过重新排列字母可以形成彼此。这个...
标题 "anagram:TDD-Anagram示例" 指向的是一个使用Test-Driven Development(TDD)方法来实现Anagram检测的JavaScript项目。在这个项目中,我们将详细探讨TDD的概念,JavaScript的基础知识,以及如何编写Anagram检测...
打开并将浏览器指向 anagram.html (例如:file:///project-directory/anagram.html) ###Copyright (c) 2015 Jill Kuchman & Jon Lin ####许可证: 特此授予任何人免费获得本软件副本和相关文档文件(“软件”)...
Anagram.java
作为一款扩展程序,Anagram Solver-crx的安装和使用十分便捷。用户只需将压缩包中的Anagram_Solver.crx文件添加到支持CRX格式的浏览器(如Chrome或Chromium)上,即可轻松开启字谜解密之旅。这种无缝集成使得玩家在...
python教学示例-anagram_db
在计算机编程的世界里,我们常常会遇到各种有趣的挑战,其中一个便是寻找字母异位词(Anagram)。字母异位词指的是两个单词由完全相同的字母组成,但字母的排列顺序不同。在本次的程序“T1_4.zip_The Program_...
在这个特定的情况下,我们有一个名为"Anagram"的Java程序,它的功能是生成字谜供用户解决。字谜是一种智力游戏,通常由打乱顺序的字母组成,玩家需要通过重组这些字母来找出隐藏的单词或短语。 在Java编程中,实现...
thinkPython配套教学脚本anagram_sets
字谜查找器 克隆此仓库 运行以下命令 $ cd anagram/ $ python3 anagrams.py sample.txt 您将看到输出为 dear,more,post,pots,Read,Rome,stop
在本项目"Ana:Java-Anagram-项目"中,我们主要关注的是使用Java语言来实现一个寻找字母异位词(Anagram)的解决方案。字母异位词是指两个单词中的字母相同,但顺序不同,比如"act"和"cat"。这个项目可能是为了帮助...
为了判断生成的字谜是否有意义,phpAG 需要一个单词库,通常是一个包含大量有效单词的文本文件。这个库可以是项目自带的,也可以由用户自定义。程序会通过读取这个文件,对比生成的排列是否与库中的单词匹配。PHP 的...
【标题】"IOS应用源码——schmidie-anagram-e27733b.rar" 指的是一款iOS应用程序的源代码,其中"schmidie-anagram"可能是该应用的项目名称或开发者名称,而"e27733b"可能是版本控制系统的特定提交ID,通常在Git中...
We utilized Near-Infrared (NIR) spectroscopy to closely investigate the activation change in anterior prefrontal cortex (aPFC) during verbal anagram problem-solving and learning. We used a parametric ...
字谜是通过重新排列不同单词或短语的字母而形成的单词或短语,通常只使用所有原始字母一次。 例如,该字字谜可被重新安排成唠叨冲压,或字的二进制到聪明或进入住所字土坯。 入门 在合适的文件夹中: git clone ...
使用Java开发的anagram软件可能包含以下组件: 1. 主程序:处理用户输入,接收单词,并生成所有可能的前置词。 2. 字典文件:存储合法单词,软件会根据此文件判断生成的前置词是否有效。 3. 字符处理算法:实现高效...
借助此扩展程序快速使您的字谜 您想做自己的名字或文字字谜吗?...使用此扩展名可以做到这一点。 它实际上是我们网站https://www.anagrammaker.online/的快捷方式。 你们两个都可以访问。 支持语言:English (UK)