`
cana_xu
  • 浏览: 2480 次
  • 性别: Icon_minigender_1
  • 来自: 南京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

使用PHP判断anagram

阅读更多

求解:在一份文本文件中,查找其中所有的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());
?>
分享到:
评论

相关推荐

    valid anagram

    给定两个字符串 `s` 和 `t`,编写一个函数来判断这两个字符串是否是异位词。即检查 `s` 和 `t` 是否包含完全相同的字符以及相同的字符频率,但字符出现的顺序可以不同。 #### 解决方案分析 为了解决这个问题,我们...

    anagram-hash:字谜哈希表

    要在浏览器中使用,请使用 。 用法 var createHash = require ( 'compute-anagram-hash' ) ; createHash( [arr] ) 创建一个哈希表。 var hash = createHash ( ) ; 要初始化哈希表,请提供一个string array 。 ...

    anagram:使用Javascript和jQuery的LEARN SD的Anagram项目

    在“anagram:使用Javascript和jQuery的LEARN SD的Anagram项目”中,我们关注的核心是利用这两种强大的技术来实现一个字母谜题(Anagram)检测器。Anagram是两个或多个单词,它们通过重新排列字母可以形成彼此。这个...

    anagram:TDD-Anagram示例

    标题 "anagram:TDD-Anagram示例" 指向的是一个使用Test-Driven Development(TDD)方法来实现Anagram检测的JavaScript项目。在这个项目中,我们将详细探讨TDD的概念,JavaScript的基础知识,以及如何编写Anagram检测...

    anagram_[removed]使用 JavaScript 进行 BDD 实践

    打开并将浏览器指向 anagram.html (例如:file:///project-directory/anagram.html) ###Copyright (c) 2015 Jill Kuchman & Jon Lin ####许可证: 特此授予任何人免费获得本软件副本和相关文档文件(“软件”)...

    Anagram.java

    Anagram.java

    Anagram Solver-crx插件

    作为一款扩展程序,Anagram Solver-crx的安装和使用十分便捷。用户只需将压缩包中的Anagram_Solver.crx文件添加到支持CRX格式的浏览器(如Chrome或Chromium)上,即可轻松开启字谜解密之旅。这种无缝集成使得玩家在...

    T1_4.zip_The Program_anagram

    在计算机编程的世界里,我们常常会遇到各种有趣的挑战,其中一个便是寻找字母异位词(Anagram)。字母异位词指的是两个单词由完全相同的字母组成,但字母的排列顺序不同。在本次的程序“T1_4.zip_The Program_...

    Anagram:一个简单的Java程序,可以生成字谜来解决

    在这个特定的情况下,我们有一个名为"Anagram"的Java程序,它的功能是生成字谜供用户解决。字谜是一种智力游戏,通常由打乱顺序的字母组成,玩家需要通过重组这些字母来找出隐藏的单词或短语。 在Java编程中,实现...

    anagram:寻找字谜

    字谜查找器 克隆此仓库 运行以下命令 $ cd anagram/ $ python3 anagrams.py sample.txt 您将看到输出为 dear,more,post,pots,Read,Rome,stop

    Ana:Java-Anagram-项目

    在本项目"Ana:Java-Anagram-项目"中,我们主要关注的是使用Java语言来实现一个寻找字母异位词(Anagram)的解决方案。字母异位词是指两个单词中的字母相同,但顺序不同,比如"act"和"cat"。这个项目可能是为了帮助...

    phpAG - PHP Anagram Generator-开源

    为了判断生成的字谜是否有意义,phpAG 需要一个单词库,通常是一个包含大量有效单词的文本文件。这个库可以是项目自带的,也可以由用户自定义。程序会通过读取这个文件,对比生成的排列是否与库中的单词匹配。PHP 的...

    IOS应用源码——schmidie-anagram-e27733b.rar

    【标题】"IOS应用源码——schmidie-anagram-e27733b.rar" 指的是一款iOS应用程序的源代码,其中"schmidie-anagram"可能是该应用的项目名称或开发者名称,而"e27733b"可能是版本控制系统的特定提交ID,通常在Git中...

    ANAGRAM PROBLEM-SOLVING AND LEARNING IN ANTERIOR PREFRONTAL CORTEX

    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 ...

    anagram:接受一段文本(希望是英语单词),并输出彼此字谜的单词组

    字谜是通过重新排列不同单词或短语的字母而形成的单词或短语,通常只使用所有原始字母一次。 例如,该字字谜可被重新安排成唠叨冲压,或字的二进制到聪明或进入住所字土坯。 入门 在合适的文件夹中: git clone ...

    anagram:一个可以获取单词所有前置词的小软件

    使用Java开发的anagram软件可能包含以下组件: 1. 主程序:处理用户输入,接收单词,并生成所有可能的前置词。 2. 字典文件:存储合法单词,软件会根据此文件判断生成的前置词是否有效。 3. 字符处理算法:实现高效...

    anagram maker-crx插件

    借助此扩展程序快速使您的字谜 您想做自己的名字或文字字谜吗?...使用此扩展名可以做到这一点。 它实际上是我们网站https://www.anagrammaker.online/的快捷方式。 你们两个都可以访问。 支持语言:English (UK)

    变位词 (Anagram)

    判断两个单词是否为变位词。 (变位词是指在不计顺序的情况下两个单词包含完全相同的字母。例如:silent和listen,garden和ranged)

    C++-leetcode题解之760. Find Anagram Mappings.cpp

    c++ C++_leetcode题解之760. Find Anagram Mappings.cpp

Global site tag (gtag.js) - Google Analytics