当前位置: 首页 > news >正文

鄂州网站设计效果叫人做网站多少钱

鄂州网站设计效果,叫人做网站多少钱,2021年uc秒懂网址推荐,建设自己的网站有钱赚么文章目录 栈的应用1.栈的括号匹配代码实战:问题分析:2.栈的表达式求值2.1 中缀、后缀、前缀表达式2.2 中缀表达式改写为后缀表达式(手算)2.3 后缀表达式的计算(手算)2.4 中缀表达式转前缀表达式(手算)和计算前缀表达式2.5后缀表达式的计算(机算)2.6 中缀表达式转后缀…

文章目录

  • 栈的应用
    • 1.栈的括号匹配
    • 代码实战:
    • 问题分析:
    • 2.栈的表达式求值
      • 2.1 中缀、后缀、前缀表达式
      • 2.2 中缀表达式改写为后缀表达式(手算)
      • 2.3 后缀表达式的计算(手算)
      • 2.4 中缀表达式转前缀表达式(手算)和计算前缀表达式
      • 2.5后缀表达式的计算(机算)
      • 2.6 中缀表达式转后缀表达式(机算)
      • 2.7 中缀表达式的计算(栈实现)
  • 3.矩阵的压缩存储
    • 3.1 对称矩阵的压缩存储
    • 3.2 三角矩阵的压缩存储
    • 3.3 三对角矩阵(带状矩阵)
    • 3.4 稀疏矩阵压缩存储
      • 3.4.1 存储方法一 结构体方式存储
      • 3.4.2 存储方法二 十字链表法

栈的应用

1.栈的括号匹配

问题分析:
问题还是很简单就是,利用栈的特性,左括号进栈,右括号出栈实现匹配,在栈空且所有括号都扫过一遍后结束
在这里插入图片描述

代码实战:

南京理工大学上机题目

苗苗今天刚刚学会使用括号,不过他分不清小括号,中括号,大括号和尖括号,不知道怎么使用这些括号,请帮助他判断括号使用是否正确。

注意:不需要区分括号的优先级。

输入格式
共一行,包含一个由 <,(,{,[,>,),},] 构成的字符串。

输出格式
如果输入的字符串中的括号正确匹配则输出 yes,否则输出 no。

数据范围
输入字符串长度不超过 10000

输入样例:

(){}

输出样例:

yes

问题分析:

  • 想到用栈来实现括号匹配的问题
  • 第一步,肯定是实现栈的基础操作(当然为了简单快捷,选择静态存储的方式实现栈)
    • 栈的定义
    • 栈的初始化
    • 入栈
    • 出栈
    • 判空
  • 具体问题具体分析
    • 写一个括号匹配函数,模拟整个过程
    • 主函数中补上字符串的输入

完整代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define MaxSize 100001
typedef struct{char data[MaxSize]; //静态数组存放栈中元素 int top;           // 栈顶元素 
}SqStack;void InitSqStack(SqStack &S)
{S.top=-1;
}bool StackEmpty(SqStack S)
{if(S.top==-1)return true;return false;
}bool Push(SqStack &S,char x)
{S.data[++S.top]=x;return true;
}bool Pop(SqStack &S,char &x)
{x=S.data[S.top--];return true;
}bool BracketCheck(char str[])
{SqStack S;InitSqStack(S);for(int i=0;i<strlen(str);i++)    //-1是因为fgets函数读入最后一个字符是/n要去掉 {if(str[i]=='<'||str[i]=='('||str[i]=='{'||str[i]=='[') //匹配到左括号 {Push(S,str[i]);}else                                                   //匹配到右括号 {	char x; Pop(S,x);if(str[i]=='>'&&x!='<')return false;if(str[i]==')'&&x!='(')return false;if(str[i]=='}'&&x!='{')return false;if(str[i]==']'&&x!='[')return false;}}return StackEmpty(S); //检索完全部括号后,栈空说明匹配成功
}
int main()
{char str[MaxSize];fgets(str,MaxSize,stdin);// 检查字符串的最后一个字符是否为换行符,并去除它  int len = strlen(str);  if (len >0&&str[len-1] =='\n') {  str[len-1] ='\0';  }  if(BracketCheck(str))printf("yes");else printf("no");
}

在这里插入图片描述

2.栈的表达式求值

2.1 中缀、后缀、前缀表达式

在学习栈的表达式求值之前 明确的概念

中缀表达式(符号在中间)

a+b
a+b-c

后缀表达式(符号在后边)

ab+
ab+c-

前缀表达式(符号在前边)

+ab
-+abc


引子:为学习计算机机算做铺垫,计算机更喜欢处理后缀表达式这种形式

2.2 中缀表达式改写为后缀表达式(手算)

  • 从左到右的找符号,找到合适的符号就把符号两边的操作数和符号写成后缀表达式的形式
    在这里插入图片描述

2.3 后缀表达式的计算(手算)

  • 从左往右扫描,每遇到一个运算符,就让运算符前面最近的两个操作数执行对应运算,合体为一个操作数
    在这里插入图片描述

从左往右我们发现,最后出现的操作数先被运算,想到栈这种数据结构

2.4 中缀表达式转前缀表达式(手算)和计算前缀表达式

类似于中缀表达式改写为后缀表达式,只是遵循的是右优先原则
在这里插入图片描述
类似于后缀表达式的计算,但是是从右边开始依次入栈,遇到符号出栈…

2.5后缀表达式的计算(机算)

  • 从左到右扫描,
  • 遇到操作数就入栈,遇到符号就将栈顶两个操作数出栈,符号计算完再入栈
  • 直到全部扫描一遍后,若表达式合法,最后栈中只会留下一个结果就是最后结果
    在这里插入图片描述

2.6 中缀表达式转后缀表达式(机算)

  • 遇到操作数,直接加入后缀表达式
  • 遇到界限符,遇到"(“直接入栈,直到遇见”)“,把此时”(“上面的所有运算符都依次出栈加入后缀表达式,注意”(“不加入,”)"也入栈
  • 遇到运算符。依次弹出栈中优先级高于或等于当前运算符的所有运算符,并加入后缀表达式,若碰到“(”或栈空则停止。之后再把当前运算符入栈。

2.7 中缀表达式的计算(栈实现)

本质就是将中缀表达式转后缀表达式和后缀表达式的计算结合起来

用栈实现中缀表达式的计算:
初始化两个栈,操作数栈和运算符栈若扫描到操作数,压入操作数栈
若扫描到运算符或界限符,则按照“中缀转后缀”相同的逻辑压入运算符栈(期间也会弹出运算符,每当弹出一个运算符时,就需要再弹出两个操作数栈的栈顶元素并执行相应运算,运算结果再压回操作数栈)

在这里插入图片描述

矩阵的压缩存储通过数组的形式来实现

3.矩阵的压缩存储

3.1 对称矩阵的压缩存储

对称矩阵
在这里插入图片描述

在这里插入图片描述

  • 对称矩阵大小存储的大小是多少

(1+n)*n/2

  • 按行优先的原则,ai,j是第几个元素(注意是第几个元素)

先算前面行一共有多少个,再加上当前的列坐标
1+2+3+…(i-1)再+j 个元素即i(i-2)/2+j个元素
如果是下标那就得-1

3.2 三角矩阵的压缩存储

下三角矩阵和上三角矩阵
在这里插入图片描述
压缩存储策略:按行优先原则将橙色区元素存入一维数组中。并在最后一个位置存储常量c
在这里插入图片描述
按行优先的原则,ai,j是第几个元素(注意是第几个元素)跟对称矩阵是一样的,当i<j的时候就是那个常数c,即n(n+1)/2

3.3 三对角矩阵(带状矩阵)

什么是三对角矩阵?
在这里插入图片描述
主对角元素的矩阵,上下左右下标差值不等于1的情况下为0
在这里插入图片描述
按行优先的原则,ai,j是第几个元素

前i-1行共3(i-1)-1个元素
ai,j是i行第j-i+2个元素
ai,j是第2i+j-2个元素
如果数组下标从0开始 k=2i+j-3

若已知数组下标k,如何得到i, j ?

前i-1行共3(i-1)-1个元素
前i行共3i-1个元素
显然,3(i-1)-1 <k+1 ≤ 3i-1
在这里插入图片描述

3.4 稀疏矩阵压缩存储

稀疏矩阵:非零元素远远少于矩阵元素的个数
压缩存储策略:
顺序存储―一三元组<行,列,值>

3.4.1 存储方法一 结构体方式存储

定义一个结构体,存储i,j,v

3.4.2 存储方法二 十字链表法

在这里插入图片描述
在这里插入图片描述

http://www.yayakq.cn/news/43578/

相关文章:

  • 站内推广有哪些方式创业初期要建立公司的网站吗
  • 代理商加盟网站网址域名注册多少钱
  • 网站分析怎么做的沈阳双兴建设集团有限公司网站
  • 铁岭市网站建设隐秘入口 黑料正能量
  • 做网站电信运营许可证免费开源商城系统源码
  • 免费的ai写作网站网页设计汽车网站建设
  • seo站长查询济南网站建设搜q.479185700
  • 学校网站构建wordpress淘宝客api
  • 西安seo网站推广优化游戏推广话术技巧
  • 潍坊市建设监理协会网站wordpress主题升级
  • php视频网站开发拍卖网站咋做
  • 广州市外贸网站建设品牌企业名词解释
  • 载网站源码 怎么下载不了商务网站推广目标有哪些
  • 建设银行网站用户名是什么意思免费建站平台官网
  • 塑胶托盘东莞网站建设品牌网站制作网站公司
  • 0基础多久学会网站架构京东网站建设目的
  • iis的默认网站没有自动启动专业制作网站 上海
  • 做网站租服务器吗php是做网站还是网页
  • 兼职网站建设收费十大经典口碑营销案例
  • 嘉兴网站制作方案个人网站开发总结文档
  • 网站推广页面设计网站建设工资 优帮云
  • 网站安全建设必要性ios风格网站模板
  • 遵义网站建设制作高德地图能不能看国外
  • 西宁建站惠州网站设计
  • 网页设计就是网站开发吗工作细胞樱花动漫
  • 教育投资网站建设方案南通企业做网站
  • 惠城营销网站制作河南省建设厅网站中州杯
  • 网站能带来什么wordpress文章页503
  • 大型网站开发费用点击最多的网站
  • wap网站制作怎么做江门做网站那家公司好