php数据结构课程---4、栈(是什么)
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、栈(是什么)的更多相关文章
- php数据结构课程---1、数据结构基础介绍(程序是什么)
php数据结构课程---1.数据结构基础介绍(程序是什么) 一.总结 一句话总结: 程序=数据结构+算法 设计好数据结构,程序就等于成功了一半. 数据结构是程序设计的基石. 1.数据的逻辑结构和物理结 ...
- javascript数据结构与算法---栈
javascript数据结构与算法---栈 在上一遍博客介绍了下列表,列表是最简单的一种结构,但是如果要处理一些比较复杂的结构,列表显得太简陋了,所以我们需要某种和列表类似但是更复杂的数据结构---栈 ...
- JavaScript数据结构和算法----栈
前言 栈是一种遵循后进先出(LIFO)原则的有序集合,新添加的或待删除的元素都保存在栈的末尾,称作栈顶,另外一端就叫栈底.在栈里,新元素都靠近栈顶,旧元素都接近栈底.可以想象桌上的一叠书,或者厨房里的 ...
- 数据结构学习之栈求解n皇后问题
数据结构学习之栈求解n皇后问题 0x1 目的 深入掌握栈应用的算法和设计 0x2 内容 编写一个程序exp3-8.cpp求解n皇后问题. 0x3 问题描述 即在n×n的方格棋盘上,放置n个皇后 ...
- Javascript数据结构与算法--栈的实现与用法
栈数据结构 栈是一种遵从后进先出(LIFO)原则的有序集合.新添加的或者待删除的元素都保存在栈的同一端,称作栈顶,另一端就叫栈底.在栈里,新元素都靠近栈顶,旧元素都接近栈底. 我们在生活中常能看到栈的 ...
- JavaScript数据结构与算法-栈练习
栈的实现 // 栈类 function Stack () { this.dataStore = []; this.top = 0; // 栈顶位置 相当于length,不是索引. this.push ...
- php数据结构课程---3、队列(队列实现方法)
php数据结构课程---3.队列(队列实现方法) 一.总结 一句话总结: 1.数据实现:适用于功能不复杂的情况 2.链表实现:受限链表,只能队头队尾操作:适用于功能复杂情况 1.队列的数组实现注意点? ...
- php数据结构课程---2、链表(php中 是如何实现单链表的(也就是php中如何实现对象引用的))
php数据结构课程---2.链表(php中 是如何实现单链表的(也就是php中如何实现对象引用的)) 一.总结 一句话总结: php是弱类型语言,变量即可表示数值,也可表示对象:链表节点的数据域的值就 ...
- SDUT 2133 数据结构实验之栈三:后缀式求值
数据结构实验之栈三:后缀式求值 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 对于一个基于二元运算符的后缀表示式(基本操作数都是 ...
随机推荐
- 《HBase in Action》 第一章节的学习总结 ---- HBase是个啥
1.HBase模仿了Google的BigTable,是一种开源的,面向列族的数据库.它基于行键(rowkey),列键(column key)和时间戳(TimeStamp)来建立索引.HBase是建立在 ...
- 最小生成树——Prim(普利姆)算法
[0]README 0.1) 本文总结于 数据结构与算法分析, 源代码均为原创, 旨在 理解Prim算法的idea 并用 源代码加以实现: 0.2)最小生成树的基础知识,参见 http://blog. ...
- Android 浏览器文本垂直居中问题
问题描述 在开发中,我们常使用 line-height 属性来实现文本的垂直居中,但是在安卓浏览器渲染中有一个常见的问题,就是对于小于12px的字体使用 line-height 属性进行垂直居中的时候 ...
- html5小趣味知识点系列(一)pubdate
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Array的push与unshift方法性能比较分析
从原理就可以知道,unshift的效率是较低的.原因是,它每添加一个元素,都要把现有元素往下移一个位置.但到底效率差异有多大呢?下面来测试一下. 测试环境的主要硬件:CPU T7100(1.8G):内 ...
- poj1861 最小生成树 prim & kruskal
// poj1861 最小生成树 prim & kruskal // // 一个水题,为的仅仅是回味一下模板.日后好有个照顾不是 #include <cstdio> #includ ...
- byte[] 、Bitmap与Drawbale 三者直接的转换
经常遇到这种类似头疼的问题 byte[] .Bitmap与Drawbale 三者直接的转换 1.byte[] ->Bitmap Bitmap Bitmap = BitmapFactory.dec ...
- Python 推导式、迭代器、生成器、模块和包
一.推导式 (一).列表推导式(集合推导式也同理于此) 利用列表推导式,取出1-20内所有偶数 li = [i for i in range(1, 21) if i % 2 == 0] # 如果只有一 ...
- 【BZOJ4070】[Apio2015]雅加达的摩天楼 set+最短路
[BZOJ4070][Apio2015]雅加达的摩天楼 Description 印尼首都雅加达市有 N 座摩天楼,它们排列成一条直线,我们从左到右依次将它们编号为 0 到 N−1.除了这 N 座摩天楼 ...
- Hibernate Criteria 查询使用
转载 http://blog.csdn.net/woshisap/article/details/6747466 Hibernate 设计了 CriteriaSpecification 作为 Crit ...