[置顶] 面试题之字符串反转

要求,如下:

首先做了一个提交表单页面,form.PHP

代码如下:

  1. <?php   
  2. header('content-type:text/html;charset=utf8 ');  
  3.   
  4.  ?>  
  5.  <center>  
  6.  <form action="fanzhuan.php" method="post">  
  7.     <input type="text" name="str">  
  8.     <br>  
  9.     <br>  
  10.     <br>  
  11.     <input type="submit" value="提交">  
  12.  </form>  
  13.  </center>  
当然,这个页面不重要,你也可以不做,直接在另一个文件中直接写死一个值;

然后,创建一个接收,并加工的页面 fanzhuan.php

代码如下:

[html] view plain copy
  1. <?php   
  2. header('content-type:text/html;charset=utf8 ');  
  3. /*  
  4.   
  5. 字符串1:Swift NSLayoutConstraint  
  6. 字符串2:Tfiws TNIartsnOctuoyalsn  
  7. 按上边字符串1转换到字符串2 的规律,编写一个字符串处理函数。  
  8.  */  
  9. $str1=isset($_POST['str'])?$_POST['str']:"";  
  10.   
  11. $len=strlen($str1);  
  12. $str_xiao=strtolower($str1);//全部转化为小写  
  13.   
  14. //函数 作用  
  15. //array_map();  数组函数:将回调函数作用到给定数组的单元上  
  16. //explode(); 字符串函数:使用一个字符串(或符号)分割另一个字符串 成为一个数组  
  17. //implode(); 数组函数:使用一个字符串(或符号)将一个数组连接为一个字符串  
  18. //strrev(); 字符串函数:将一个给定的字符串实现反转  
  19.   
  20.   
  21. $str2=implode(' ',array_map('strrev',explode(' ',$str_xiao)));  
  22.   
  23. //在这里应用了四个函数  
  24. //1.应用explode函数  通过字符串的空格 实现把字符串转换为数组  
  25. //2.应用array_map函数 将数组的内容 实现反转  
  26. //3.应用implode函数 将反转后的数组 重新连接为字符串  
  27.   
  28. for ($i=0; $i < $len; $i++) {   
  29.   
  30.     checkcase($str1[$i])?$str2[$i]=strtoupper($str2[$i]):$str2[$i]=strtolower($str2[$i]);  
  31.     //解释:三目运算符  
  32.     //在for循环中 调用下方的自定义函数 来判断每一个字母的大小写  
  33.     //true 则使用strtoupper将该字母变成大写   
  34.     //false 则使用strtolower将该字母变小写  
  35. }  
  36.   
  37.   
  38. function checkcase($aa){  
  39.       
  40.     if(preg_match('/^[A-Z]+$/', $aa))//通过正则判断大小写  
  41.     {  
  42.         return true;  
  43.     }else{  
  44.         return false;  
  45.     }  
  46. }  
  47.   
  48. echo $str2;//最后输出  
  49.  ?>  

2:

<?php
    header("content-type:text/html;charset=utf-8");
    $str = "Swift NSLayoutConstraint";
    // echo $str;
    $arr = explode(" ",$str);
    // print_r($arr);die;

    echo "<pre>";
    
    for ($i=0; $i < count($arr); $i++) {
        for($a=0; $a<strlen($arr[$i]);$a++){
            if(check($arr[$i][$a]) == 1){
                $ar[$i][$a] = $a;
            }
        }
    }
    // print_r($ar);

    $str = strtolower($str);
    $arr1 = explode(" ",$str);
    for ($i=0; $i < count($arr1); $i++) {
        $arr2[$i] = strrev($arr1[$i]);
    }
    // print_r($arr2);


    for($a=0;$a<count($arr2);$a++){
        for($i=0;$i<strlen($arr2[$a]); $i++){
            foreach($ar[$a] as $k => $vv){
                if($i == $vv){
                    $arr2[$a][$i] = strtoupper($arr2[$a][$i]);
                }
            }
        }
    }

    // print_r($arr2);
    echo $arr2[0]." ".$arr2[1];
    
    function check($str){
        if(preg_match('/^[A-Z]$/',$str)){
            return 1;
        }
    }

?>


3:

<?php
    header('content-type:text/html;charset=utf-8');
    $str = "Swift NSLayoutConstraint";
    echo $str;
    echo "<br>";

    $arr = str_split($str);
    foreach($arr as $k => $v){
        // echo $v;
        if(preg_match('/^[A-Z]$/',$v)){
            $ar[] = $k;
        }
    }
    // print_r($ar);die;
    $str1 = '';
    $ars = explode(" ",$str);
    foreach($ars as $k => $v){
        $ar1[$k] = strtolower(strrev($v));
        $str1 .= $ar1[$k]." ";
    }
    // echo $str1;die;
    $str11 = str_split($str1);
    // print_R($str11);die;
    foreach($ar as $k => $v){
        $str11[$v] = strtoupper($str11[$v]);
    }
    echo implode($str11);
    // print_r($str11);
?>


你可能感兴趣的:([置顶] 面试题之字符串反转)