百度贴吧php面试题,昨晚hr给了我一个面试题,说过了就安排我面试

本文深入探讨了一段PHP代码,该代码涉及循环逻辑、条件判断以及对PHP基本函数的运用。主要关注点在于理解循环次数不确定的情况下的逻辑处理,以及通过AJAX进行后台计算结果与前台页面颜色渲染的交互。代码中包含了生成随机数组、判断特定条件(w1、e、l1)以及计算最终得分的功能。通过这个案例,读者可以提升在PHP编程和前端数据交互方面的能力。
摘要由CSDN通过智能技术生成

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

//考察1:读懂题

//考察2:有漏洞,不说小循环循环几次,考验逻辑能力

//考察3:三种情况如何判断,对php基本函数掌握情况

//考察4:ajax数据传输

//考察5:前台页面渲染颜色

//只用 php写了计算部分,后边颜色渲染ajax以后自己js写吧

api(5);

//$for_num 大N,用户要循环的次数

function api($for_num){

$for_num = 5;//循环次数N

$return =array();

$return['arr'] = array();//存储每次结果

$return['R'] = 0;//最终结果

$return['w1'] = 0;//最终w1次数

$return['e'] = 0;//最终e1次数

$return['l1'] = 0;//最终l1次数

$return['empty'] = 0;//执行时前三种情况落空次数

for($i=0;$i

$re = judge();

switch ($re['state']) {

case 'w1':

$return['w1']+=1;

break;

case 'e':

$return['e']+=1;

break;

case 'l1':

$return['l1']+=1;

break;

default :

$return['empty']+=1;

break;

}

$return['arr'][] = $re;

}

$return['R'] = $return['w1'] * 4

+$return['l1'] * (-8);

var_dump('R:',$return['R']);

var_dump('w1:',$return['w1']);

var_dump('e:',$return['e']);

var_dump('l1:',$return['l1']);

var_dump('empty:',$return['empty']);

var_dump($return['arr']);

}

//执行函数-进行判断

function judge(){

$return = array();

$tmp_arr = make_rand_arr();

$return['arr'] = $tmp_arr;

//1.判断w1情况

$re = judge_w1($tmp_arr);

if($re) {

$return['state'] ='w1';

return $return;

}

//2.判断E

$re = judge_e($tmp_arr);

if($re) {

$return['state'] ='e';

return $return;

}

//3.判断L1

$re = judge_l($tmp_arr);

if($re) {

$return['state'] ='l1';

return $return;

}

//4.都没命中,返回false

$return['state'] =false;

return $return;

}

//子函数:制造随机函数

function make_rand_arr(){

$w = 0;

$j = 100; //每一轮产生随机数的次数

$tmp_arr = array();

$i = 0;

while($i < $j){

$rand_num = mt_rand(0,1);

if($rand_num == 1){

$w -= 1;

}else{

$w += 1;

}

$tmp_arr[] = $w;//归组

$i+=1;

}

return $tmp_arr;

}

//子函数:判断w1

function judge_w1($tmp_arr)

{

$key = array_search('4',$tmp_arr);

if($key !== false){

//4以前的所有数字

$tmp_arr = array_slice($tmp_arr,0,$key);

if(!in_array('-6',$tmp_arr)){

//如果4以前没有出现过6

return true;

}

}

return false;

}

//子函数:判断e

function judge_e($tmp_arr)

{

$key = array_search('-6',$tmp_arr);

if($key !== false){

//-6以前的所有数字

$tmp_arr_pre = array_slice($tmp_arr,0,$key);

//-6以后的所有数字

$tmp_arr_bottom = array_slice($tmp_arr,$key+1,count($tmp_arr));

if( !in_array('4',$tmp_arr_pre) ){

//如果前边没出现过4

//后数组没出现小于-6

foreach($tmp_arr_bottom as $k=>$v){

if($v

return false;

}

}

return true; //只有出现-6,前无4,后都大于-6,true

}

}

return false; //如果没有出现-6,返回false

}

//子函数:判断l

function judge_l($tmp_arr)

{

$key = array_search('-6',$tmp_arr);

if($key !== false){

//-6以前的所有数字

$tmp_arr_pre = array_slice($tmp_arr,0,$key);

//-6以后的所有数字

$tmp_arr_bottom = array_slice($tmp_arr,$key+1,count($tmp_arr));

if( !in_array('4',$tmp_arr_pre) && in_array('-8',$tmp_arr_bottom) && !in_array('0',$tmp_arr_bottom) ){

//如果之前没出现4,之后没出现0,之后出现了-8

return true;

}

}

return false; //如果没有出现-6,返回false

}

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
随着人口老龄化和空巢化等社会问题的日益严峻,养老问题及以及养老方式的变革成为了当前社会的发展焦点,传统的养老模式以救助型和独立型为主,社会养老的服务质量与老年人的养老需求还存在一定的差距,人们生活水平的提高以及养老多元化需求的增加都需要通过创新和灵活开放的养老模式来应对未来的养老需求,结合目前我国养老模式及养老服务问题的内容的分析,互助养老模式作为一种新型的养老模式结合自主互助的集体养老理念,帮助老年人实现了满足个性需求的养老方案,互助养老模式让老年人具备了双重角色的同时也实现可持续的发展特色。目前我国老年人的占比以每年5%的速度在飞速增长,养老问题及养老服务的提供已经无法满足当前社会养老的切实需求,在养老服务质量和养老产品的变革过程中需要集合多元化的养老模式来满足更多老人的养老需求。 鉴于我国目前人口老龄化的现状以及迅速扩张的养老服务需求,现有的养老模式已经无法应对和满足社会发展的需求,快速增长的养老人员以及养老服务供给不足造成了紧张的社会关系,本文结合当前养老服务的发展需求,利用SSM框架以及JSP技术开发设计一款正对在线互助养老的系统,通过系统平台实现养老机构信息的传递及线上预约,搭建了起了用户、养老机构以及系统管理员的三方数据平台,借助网页端实现在线的养老互助信息查询、养老机构在线预约以及求助需求等功能,通过自养互养的养老模式来帮助老年人重新发现自我价值以及丰富养老的主观能动性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值