PHP的三道面试题,求解,谢谢

一生小白 2018-03-28 08:34:34
...全文
349 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
一生小白 2018-03-29
  • 打赏
  • 举报
回复
谢谢!我第一题也找到了,稍微改了一下,但是不知道怎么添加特殊处理,1.1万的这个
function chrtonum($str){
    $num=0;
    $bins = array("零","一","二","三","四","五","六","七","八","九",'a'=>"个",'b'=>"十",'c'=>"百",'d'=>"千",'e'=>"万");//定义验证规则数组
    $bits = array('a'=>1,'b'=>10,'c'=>100,'d'=>1000,'e'=>10000);//定义十位数以上的对应替换数组
    //匹配验证规则,并替换
    foreach($bins as $key=>$val){
        if(strpos(" ".$str,$val)) $str=str_replace($val,$key,$str);

    }
    //分割字符串
    foreach(str_split($str,2) as $val){

        $temp=str_split($val,1);
        if(count($temp)==1) $temp[1]="a";
        if(isset($bits[$temp[0]])){
            $num=$bits[$temp[0]]+(int)$temp[1];
        }else{
            $num+=(int)$temp[0]*$bits[$temp[1]];
        }
    }
    return $num;
}
引用 2 楼 xuzuning 的回复:
2、
print_r(top(5, [1,2,3,1,2,3,4,0,4,6,8,7,5]));

function top($N, $seq) {
  $d = floor($N / 2);
  $len = count($seq);
  foreach($seq as $i=>$v) {
    if($i - $d >= 0 && $i + $d < $len && $v >= $seq[$i - $d] && $v >= $seq[$i + $d])
      $r[$i] = $v;
  }
  return $r;
}
瓜皮猫 2018-03-29
  • 打赏
  • 举报
回复
我可能用的是个假php,我连答案代码都看不懂。
果酱很好吃 2018-03-29
  • 打赏
  • 举报
回复
2、

$n = 5;
$seq = [1,2,3,1,2,3,4,0,4,6,8,7,5];
echo "<pre>";
print_r(top($n,$seq));
echo "</pre>";
function top($n,$arr){
    $mid = ceil($n / 2);
    $count = count($arr);
    $data = [];
    $tmp = [];
    foreach($arr as $k=>$v){
        if($k < $mid-1){
            continue;
        }
        if(($k + $mid) > $count){
            break;
        }
        for($i=1;$i<=$n;$i++){
            $tmp[] = $i < $mid ? $arr[$k-$i] : $arr[$k+$i-$mid];
        }
        if(max($tmp)==$v){
            $data[$k] = $v;
        }
        $tmp = [];
    }
    return $data;
}
3、另一种解法

$arr = array_combine(range('A','Z'),range('a','z'));
echo strtr('AbSiuAds',array_merge($arr,array_flip($arr)));
xuzuning 2018-03-29
  • 打赏
  • 举报
回复
2、
print_r(top(5, [1,2,3,1,2,3,4,0,4,6,8,7,5]));

function top($N, $seq) {
  $d = floor($N / 2);
  $len = count($seq);
  foreach($seq as $i=>$v) {
    if($i - $d >= 0 && $i + $d < $len && $v >= $seq[$i - $d] && $v >= $seq[$i + $d])
      $r[$i] = $v;
  }
  return $r;
}
xuzuning 2018-03-29
  • 打赏
  • 举报
回复
3、
$s = 'AbSiuads';
$r = join('', array_map(function($c) { return chr(ord($c)^32); }, str_split($s)));
echo $r;
一生小白 2018-03-29
  • 打赏
  • 举报
回复
引用 3楼果酱很好吃 的回复:
2、

$n = 5;
$seq = [1,2,3,1,2,3,4,0,4,6,8,7,5];
echo "<pre>";
print_r(top($n,$seq));
echo "</pre>";
function top($n,$arr){
    $mid = ceil($n / 2);
    $count = count($arr);
    $data = [];
    $tmp = [];
    foreach($arr as $k=>$v){
        if($k < $mid-1){
            continue;
        }
        if(($k + $mid) > $count){
            break;
        }
        for($i=1;$i<=$n;$i++){
            $tmp[] = $i < $mid ? $arr[$k-$i] : $arr[$k+$i-$mid];
        }
        if(max($tmp)==$v){
            $data[$k] = $v;
        }
        $tmp = [];
    }
    return $data;
}
3、另一种解法

$arr = array_combine(range('A','Z'),range('a','z'));
echo strtr('AbSiuAds',array_merge($arr,array_flip($arr)));
第二天能给备注一下吗?

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧