>> 本文固定链接: http://php.ncong.com/mianshi/mianshiti_string.html

>> 转载请注明: 恩聪php 2014年09月02日 于 恩聪PHP学习教程 发表

1.不用PHP函数,用方法写一个反转字符串的函数。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
    $str = "hello";
 
    function fan($str) {
        //声明一个临时的变量
        $n = "";
        //获取字符串长度
        $m = strlen($str)-1;
        for($i=$m; $i >= 0;  $i--) {
            $n .= $str{$i};
        }  
        return $n;
    }
    echo fan($str);
?>

2.写一个函数,将一个字符串(如:1234567890),转换成(如1,234,567,890)每3位用逗号隔开的形式。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php
    $str = "12345678932132";
 
    function nformat($str) {
        $n = "";   //临时的变量
        $m = strlen($str); //获取字符串长度
        $k = $m %  3;  //让整个长度和3取余之后余数是多少 = 0
 
        for($i=0; $i < $m$i++) {
            if($i%3 == $k && $i!=0) {
                $n .=",";
            }
            $n .= $str{$i};
        }
        return $n;
    }
    echo nformat($str);
?>

3.请写一个获取文件扩展名的函数。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<?php
    function extname($url) {
        if(strstr($url, "?")) {
            //如果有问号格式的文件, 将问号前的文件取出给变量$file
            list($file) = explode("?", $url);
        } else {
            $file = $url;
        }
 
        //以下是第二步取出文件名
        $loc = strrpos($file, "/")+1;      
        $filename = substr($file, $loc);
 
        //以下是第三步取扩展名称
        $arr = explode(".", $filename);
 
        //弹出数组最后一个元素
        return array_pop($arr);
    }
    echo extname("http://***/aaa/init.inc.php")."<br>";
    echo extname("init.inc.php")."<br>";
    echo extname("C:/aaa/init.inc.php")."<br>";
    echo extname("http://***/aaa/init.inc.php?a=100")."<br>";
?>

4.写一个函数,算出两个文件的相对路径。

如:
$a=’/a/b/c/d/e.php’
$b=’/a/b/12/34/c.php’
计算出$b相对于$a的相对路径应该是../../c/d

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<?php
    function abspath($a, $b) {
 
        //第一步去除公共的目录结构
        //  $a = "/a/b/c/d/e.php";
        //  $b = "/a/b/12/34/c.php";
 
        $a = dirname($a);    //  /a/b/c/d
        $b = dirname($b);    //  /a/b/12/34
 
        $a = trim($a, "/");   //   a/b/c/d
        $b = trim($b, "/");   //   a/b/12/34
 
        $a = explode("/", $a);  //  array("a", "b", "c", "d")
        $b = explode("/", $b);  //  array("a", "b", "12", "34")
 
        //合并上面代码相当于 $a = explode("/", trim(dirname($a), "/"));
        $num = max(count($a), count($b));
 
        for($i=0; $i<$num; $i++) {
            if($a[$i]==$b[$i]) {
                unset($a[$i]);
                unset($b[$i]);
            }else{
                break;
            }
        }
 
        //$a = array("c", "d");
        //$b = array("12", "34");
        //第二步:回到同级目录, 进入另一个目录
 
         $path = str_repeat("../", count($b)).implode("/", $a);    //  ../../c/d
 
        return $path;
    }
 
    $a = "/a/b/c/d/e/w/f/e.php";
    $b = "/a/b/12/34/100/c.php";
 
    // ../../c/d
    echo abspath($a, $b);
?>
 

php字符串常见面试题的更多相关文章

  1. java常见面试题及答案 1-10(基础篇)

    java常见面试题及答案 1.什么是Java虚拟机?为什么Java被称作是"平台无关的编程语言"? Java 虚拟机是一个可以执行 Java 字节码的虚拟机进程.Java 源文件被 ...

  2. iOS常见面试题汇总

    iOS常见面试题汇总 1. 什么是 ARC? (ARC 是为了解决什么问题而诞生的?) ARC 是 Automatic Reference Counting 的缩写, 即自动引用计数. 这是苹果在 i ...

  3. JDBC常见面试题

    以下我是归纳的JDBC知识点图: 图上的知识点都可以在我其他的文章内找到相应内容. JDBC常见面试题 JDBC操作数据库的步骤 ? JDBC操作数据库的步骤 ? 注册数据库驱动. 建立数据库连接. ...

  4. Mybatis常见面试题

    Mybatis常见面试题 #{}和${}的区别是什么? #{}和${}的区别是什么? 在Mybatis中,有两种占位符 #{}解析传递进来的参数数据 ${}对传递进来的参数原样拼接在SQL中 #{}是 ...

  5. JavaSE:数据类型之间的转换(附常见面试题)

    数据类型之间的转换 分为以下几种情况: 1)低级到高级的自动类型转换: 2)高级到低级的强制类型转换(会导致溢出或丢失精度): 3)基本类型向类类型转换: 4)基本类型向字符串的转换: 5)类类型向字 ...

  6. 整理的最全 python常见面试题(基本必考)

    整理的最全 python常见面试题(基本必考) python 2018-05-17 作者 大蛇王 1.大数据的文件读取 ① 利用生成器generator ②迭代器进行迭代遍历:for line in ...

  7. PHP常见面试题汇总(二)

    PHP常见面试题汇总(二)   //第51题:统计一维数组中所有值出现的次数?返回一个数组,其元素的键名是原数组的值;键值是该值在原数组中出现的次数 $array=array(4,5,1,2,3,1, ...

  8. java常见面试题及答案

    java常见面试题及答案 来源 https://blog.csdn.net/hsk256/article/details/49052293 来源 https://blog.csdn.net/hsk25 ...

  9. python爬虫常见面试题(一)

    前言 之所以在这里写下python爬虫常见面试题及解答,一是用作笔记,方便日后回忆:二是给自己一个和大家交流的机会,互相学习.进步,希望不正之处大家能给予指正:三是我也是互联网寒潮下岗的那批人之一,为 ...

随机推荐

  1. 【字符串】【最小表示法】Vijos P1683 有根树的同构问题

    题目链接: https://vijos.org/p/1683 题目大意: 给M棵树,每棵N个点,N-1条边,树边有向,问哪些树同构. 题目思路: [字符串][最小表示法] 用()表示一个节点,那么三个 ...

  2. Container With Most Water——LeetCode

    Given n non-negative integers a1, a2, ..., an, where each represents a point at coordinate (i, ai).  ...

  3. 【转】 Linux/Unix 进程间通信的各种方式及其比较

    http://blog.csdn.net/guopengzhang/article/details/5528260 进程间通信就是在不同进程之间传播或交换信息,那么不同进程之间存在着什么双方都可以访问 ...

  4. 360. Sort Transformed Array

    一元二次方程...仿佛回到了初中. 主要看a的情况来分情况讨论: =0,一次函数,根据b的正负单调递增递减就行了. <0,凸状..从nums[]左右两边开始往中间一边比较一边 从右往左 放: 0 ...

  5. angularJS 指令一

    指令1.指令本质上就是AngularJS拓展具有自定义功能的HTML元素的途径.通过自定义元素来创建指令,如:<my-directive></my-directive>.dir ...

  6. xargs 参数

    hadoop fs -ls /source/recommend/at_access | awk -F "/" '{print $NF}' | grep -v $(date +%Y% ...

  7. .net core4

  8. Hadoop 的子项目

    Hadoop Common: 在0.20及以前的版本中,包含HDFS.MapReduce和其他项目公共内容,从0.21开始HDFS和MapReduce被分离为独立的子项目,其余内容为Hadoop Co ...

  9. HDU--杭电--1253--胜利大逃亡--广搜

    胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  10. HDOJ 5184 Brackets 卡特兰数扩展

    既求从点(0,0)仅仅能向上或者向右而且不穿越y=x到达点(a,b)有多少总走法... 有公式: C(a+b,min(a,b))-C(a+b,min(a,b)-1)  /// 折纸法证明卡特兰数: h ...