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 有疑问?点这里^_^ 题目描述 对于一个基于二元运算符的后缀表示式(基本操作数都是 ...
随机推荐
- NHibernate 数据查询之Linto to NHibernate (第八篇)
NHibernate 数据查询之Linto to NHibernate (第八篇) 刚学NHibernate的时候觉得,HQL挺好用的,但是终归没有与其他技术 相关联,只有NHibernate用到,一 ...
- .net 字符串驻留
.net中的string表达的是常量字符串. JIT编译器编译时判断遇到的常量字符串是否在内部散列表中,如果不在,添加进去.当第一次执行到含字符串的方法时,CLR会检查该字符串是否在内部的一个散列表中 ...
- 读取Excel中的数据到DataSet
读取Excel中的数据到DataSet 1.引用命名空间 using System.Data.OleDb; 2.输入Excel文件,输出DataSet public DataSet ExecleDs( ...
- PHP-Manual的学习----【语言参考】----【类型】-----【Interger类型】
2017年7月20日15:48:46Integer 整型 1.什么是整数?正数 0 负数2.整型值可以使用十进制,十六进制,八进制或二进制表示,前面可以加上可选的符号(- 或者 +). 二进制表达的 ...
- python 基础 9.7 创建表
一. 创建表 #/usr/bin/python #-*- coding:utf-8 -*- #@Time :2017/11/22 18:05 #@Auther :liuzhenchuan #@Fi ...
- P1009 阶乘之和
P1009 阶乘之和 题目提供者洛谷OnlineJudge 标签数论(数学相关)高精1998NOIp提高组NOIp普及组 难度普及- 通过/提交1139/3791 提交该题 讨论 题解 记录 题目描述 ...
- 【BZOJ4537】[Hnoi2016]最小公倍数 分块
[BZOJ4537][Hnoi2016]最小公倍数 Description 给定一张N个顶点M条边的无向图(顶点编号为1,2,…,n),每条边上带有权值.所有权值都可以分解成2^a*3^b的形式.现在 ...
- height为auto, 滚动条出现时, 使页面不跳动
<style> html { margin-left: calc(100vw - 100%); } </style> ;
- sublime 快捷键,左菜单乱码
sublime 快捷键安装 packagecontrol https://packagecontrol.io/installation#st3 import urllib.request,os,has ...
- 如何从统计中批量获取BD搜索关键词及对应的入口页面?
前面我们介绍了通过cnzz的访问明细获取到搜索关键词及对应的入口页面,但是从BD搜索进来的关键词无法完整显示,只能呈现一些bd图片搜索的关键词,这是因为百度宣布从去年5月开始逐渐取消了referer关 ...