php数据结构课程---4、栈(是什么)

一、总结

一句话总结:

栈(stack),它是一种运算受限的线性表。其限制是仅允许在表的一端进行插入和删除运算。

1、栈的链表实现?

定义node,设置属性data,prev
定义stack类,设置栈顶top,size
编写出栈push(),pop()函数
返回栈所有数据函数getAll()
<?php 

class Node{
public $data = null;
public $prev = null; public function __construct($data){
$this->data = $data;
}
} class stack{
private $top = null;
public $size = 0; public function push($data)
{
if($this->top == null){
$this->top = new Node($data);
}else{
$n = new Node($data);
$n->prev = $this->top;
$this->top = $n;
}
$this->size++;
} public function pop()
{
$data = $this->top->data;
$this->top = $this->top->prev;
$this->size--;
return $data;
} public function getAll(){
$result = [];
while($this->top){
$result[]=$this->top->data;
$this->top = $this->top->prev;
}
return $result;
} } // $s = new stack();
// $s->push("aaaa");
// $s->push("bbb");
// $s->push("dddddd");
// $s->push("cc");
// $s->push("eeee");
// echo '<pre>';
// echo $s->pop(); // var_dump($s->getAll());

2、数组模拟栈?

array_push() array_pop()
//数组模拟栈

$stack = [];
array_push($stack,"aaa");
array_push($stack,"bbb");
array_push($stack,"ccc");
array_push($stack,"ddd");
array_push($stack,"eee");
echo array_pop($stack);
echo array_pop($stack);

3、括号匹配应用(比如[[()]()])?

算法思路:如果是左边的括号,就将对应的右括号押进栈,如果是右边的括号,判断栈里面是否有这个括号,没有说明不匹配
<?php 

$stack =  new SplStack();

$str = "[[[]](){}]";
echo $str."</br>";
$symbols =["("=>")","["=>"]","{"=>"}"];
// $keys =["(","[","{"];
// $values = [")","]","}"]; $result = "匹配";
for ($i=0; $i < strlen($str) ; $i++) {
if(in_array($str[$i], array_keys($symbols))){
$stack->push($symbols[$str[$i]]);
}else if(in_array($str[$i], array_values(($symbols)))){
if(!$stack->isEmpty()){
if($str[$i] != $stack->pop()){
$result = "不匹配!";
break;
}
}else{
$result = "不匹配!";
break;
}
}
}
if($stack->isEmpty()){
echo $result;
}else{
echo "不匹配!!";
} // $stack = new SplStack();
// $str = "[[()][]";
// // $str = "[()][]]";
// echo $str."</br>"; // for ($i=0; $i < strlen($str); $i++) {
// if ($str[$i] == "[") {
// $stack->push("]");
// }elseif ($str[$i] == "(") {
// $stack->push(")");
// }elseif ($str[$i] == ")") {
// if(!$stack->isEmpty()){
// $pop = $stack->pop();
// if($pop != ")"){
// echo "not match!";exit;
// }
// }else{
// echo "not match!";exit;
// }
// }elseif ($str[$i] == "]") {
// if(!$stack->isEmpty()){
// $pop = $stack->pop();
// if($pop != "]"){
// echo "not match!";exit;
// }
// }else{
// echo "not match!";exit;
// }
// }
// }
// if($stack->isEmpty()){
// echo "匹配!";
// }else{
// echo "不匹配!!";
// }

4、八皇后的栈实现(不在同一条横线,竖线,左斜线,右斜线上)?

已选取的元素存入栈
判断左右斜线:$i和$j的差值
<?php 

class Queen{
// 多少皇后
public $n;
// 记录多少种摆法
public $count;
//栈
public $stack; public function __construct($n=8){
$this->n=$n;
$this->stack = new SplStack();
} //摆放n皇后
public function place($n=8){
//结束条件,找到一个解
if($this->stack->count() == $this->n ){
$this->count++;
$this->map($this->stack);
return;
}
//摆放第n个皇后,探索水平方向值
for ($i=0; $i < $this->n ; $i++) {
//探索水平位置,值为$i
$this->stack->push($i);
if($this->check()){
$this->place($n-1);
}
//探索水平位置下个值
$this->stack->pop();
}
} public function check(){
for ($i=1; $i < $this->stack->count() ; $i++) {
if($this->stack[$i] == $this->stack[0] || abs($this->stack[$i]-$this->stack[0]) == $i){
return false;
}
}
return true;
}
public function map(){
echo "<table>";
for ($i=0; $i < $this->n; $i++) {
echo "<tr>";
for ($j=0; $j < $this->n; $j++) {
echo "<td>";
if($this->stack[$i]==$j){
echo "Q";
}
echo "</td>";
}
echo "</tr>";
}
echo "</table>";
} } $n=8;
$q = new Queen($n);
$q->place($n);
echo "<table><tr><td class='count'>一共有 $q->count 个摆法。</td></tr></table>";
?>
<style>
table{
margin:15px 15px;
float:left;
}
td{
width: 15px;
height: 15px;
border:1px solid red;
}
.count{
width:150px;
}
</style>

5、用php敲算法问题的好处是什么?

结果可以以网页的形式美观的打印出来

二、内容在总结中

 

php数据结构课程---4、栈(是什么)的更多相关文章

  1. php数据结构课程---1、数据结构基础介绍(程序是什么)

    php数据结构课程---1.数据结构基础介绍(程序是什么) 一.总结 一句话总结: 程序=数据结构+算法 设计好数据结构,程序就等于成功了一半. 数据结构是程序设计的基石. 1.数据的逻辑结构和物理结 ...

  2. javascript数据结构与算法---栈

    javascript数据结构与算法---栈 在上一遍博客介绍了下列表,列表是最简单的一种结构,但是如果要处理一些比较复杂的结构,列表显得太简陋了,所以我们需要某种和列表类似但是更复杂的数据结构---栈 ...

  3. JavaScript数据结构和算法----栈

    前言 栈是一种遵循后进先出(LIFO)原则的有序集合,新添加的或待删除的元素都保存在栈的末尾,称作栈顶,另外一端就叫栈底.在栈里,新元素都靠近栈顶,旧元素都接近栈底.可以想象桌上的一叠书,或者厨房里的 ...

  4. 数据结构学习之栈求解n皇后问题

    数据结构学习之栈求解n皇后问题 0x1 目的 ​ 深入掌握栈应用的算法和设计 0x2 内容 ​ 编写一个程序exp3-8.cpp求解n皇后问题. 0x3 问题描述 即在n×n的方格棋盘上,放置n个皇后 ...

  5. Javascript数据结构与算法--栈的实现与用法

    栈数据结构 栈是一种遵从后进先出(LIFO)原则的有序集合.新添加的或者待删除的元素都保存在栈的同一端,称作栈顶,另一端就叫栈底.在栈里,新元素都靠近栈顶,旧元素都接近栈底. 我们在生活中常能看到栈的 ...

  6. JavaScript数据结构与算法-栈练习

    栈的实现 // 栈类 function Stack () { this.dataStore = []; this.top = 0; // 栈顶位置 相当于length,不是索引. this.push ...

  7. php数据结构课程---3、队列(队列实现方法)

    php数据结构课程---3.队列(队列实现方法) 一.总结 一句话总结: 1.数据实现:适用于功能不复杂的情况 2.链表实现:受限链表,只能队头队尾操作:适用于功能复杂情况 1.队列的数组实现注意点? ...

  8. php数据结构课程---2、链表(php中 是如何实现单链表的(也就是php中如何实现对象引用的))

    php数据结构课程---2.链表(php中 是如何实现单链表的(也就是php中如何实现对象引用的)) 一.总结 一句话总结: php是弱类型语言,变量即可表示数值,也可表示对象:链表节点的数据域的值就 ...

  9. SDUT 2133 数据结构实验之栈三:后缀式求值

    数据结构实验之栈三:后缀式求值 Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述 对于一个基于二元运算符的后缀表示式(基本操作数都是 ...

随机推荐

  1. oracle快速复制表数据

    方法一: 只复制表结构: create table table_name_new as select * from table_name_old where 1=2; 然后: alter sessio ...

  2. Unix下网络编程概述

    这部分我要学习的是Unix下的网络编程,参照的书籍是W. Richard. Stevens的<Unix网络编程>卷一和卷二,由于本身现在从事的工作是java后台开发,对客户端-服务器的这种 ...

  3. nginx反向代理带路径访问问题

    nginx的配置为192.168.0.219:80分别映射到upstream组192.168.0.55:8080和192.168.0.206:8080,那如何配置做到访问192.168.0.219:8 ...

  4. 在Servlet的GenericServlet类中为什么有两个init()方法

    想要搞清楚这件事情,必须先了解Servlet容器调用Servlet的过程.调用过程如下 首次访问该Servlet1.调用init(ServletConfig config) 进行初始化,Servlet ...

  5. html自定义标签属性

    <a href="#" _asd="xxxx" onclick="test(event)">test</a> < ...

  6. Python snap

    orderedDict enum sys.path 注册装饰器 装饰器检查 入参 Flask01 flask_script flask blue print functools.partial dns ...

  7. 如何简单的实现一个tab页title的动画效果

    首先我们来看看实现的效果 tab上的title沉下去的效果 先来看看布局 <?xml version="1.0" encoding="utf-8"?> ...

  8. SET IDENTITY_INSERT ON/OFF 权限

    今天突然遇到了,找不到对象“XXXX”,因为它不存在或者没有您所需的权限,于是检查程序,突然发现程序中有一段代码是: SET IDENTITY_INSERT eticket ON //执行业务 ... ...

  9. EL 表达式 函数 操作 字符串

    <%@tablib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %> ${fn ...

  10. elasticsearch从入门到出门-08-Elasticsearch容错机制:master选举,replica容错,数据恢复

    假如: 9 shard,3 node Elasticsearch容错机制:master选举,replica容错,数据恢复 最佳分配情况: 这样分配之后,不管其中哪个node 宕机这个es 依然可以提供 ...