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

网站怎么做图片动态图片不显示不出来的工作室logo设计

网站怎么做图片动态图片不显示不出来的,工作室logo设计,自助建站整站源码,关于网站建设资金的报告💓 博客主页:C-SDN花园GGbond ⏩ 文章专栏:数据结构经典题目刨析(c语言) 目录 一、题目描述 二、解题思路 三、代码实现 一、题目描述 二、解题思路 问题要求将三种类型括号匹配,其中包括顺序匹配和数量匹配 使用栈的后进先…

💓 博客主页:C-SDN花园GGbond

⏩ 文章专栏:数据结构经典题目刨析(c语言)

目录

一、题目描述

二、解题思路 

三、代码实现 


 

一、题目描述

二、解题思路 

问题要求将三种类型括号匹配,其中包括顺序匹配数量匹配

使用栈的后进先出结构可以很好的解决这个问题:

根据栈独有的特点,具体操作:1、属于左括号,进行入栈处理。2、属于右括号进行出栈处理,然后进行匹配,不匹配就报错。我们既然选择用C语言来实现,就需要我们自己提前实现一个栈结构

先实现栈 :

//栈的初始化
void STInit(ST* pst)
{assert(pst);pst->a = NULL;pst->top = pst->capacity = 0;//top指向栈顶元素的下一个位置}
void STDestroy(ST* pst)
{assert(pst);free(pst->a);pst->a = NULL;pst->top = pst->capacity = 0;}
void STPush(ST* pst, STDatyType x)
{assert(pst);if (pst->top == pst->capacity){int newcapacity=pst->capacity==0 ? 4 : pst->capacity * 2;STDatyType* tmp =(STDatyType*)realloc(pst->a, newcapacity * sizeof(STDatyType));if (tmp == NULL){perror("ralloc fail");return;}pst->capacity = newcapacity;pst->a = tmp;}pst->a[pst->top] = x;pst->top++;
}
//出栈
void STPop(ST* pst)
{assert(pst);assert(pst->top > 0);pst->top--;
}
//得到栈顶元素
STDatyType STTop(ST* pst)
{assert(pst);assert(pst->top > 0);return pst->a[pst->top - 1];
}
//判空
bool STEmpty(ST* pst)
{assert(pst);return pst->top == 0;
}
//获取数据个数
int STSize(ST* pst)
{assert(pst);return pst->top;
}

遍历字符串
遇到左括号则压栈等待右括号匹配;
遇到右括号先进行判断,首先判断栈是否为空,如果为空则不可能完成匹配,直接判定无效


上述判定不成立再进行下列判断
如果此时栈顶的数据是与右括号匹配的左括号,则出栈,否则直接判定无效(顺序不匹配)
当字符串遍历完成时,如果栈为空,则说明括号全部匹配上了;否则说明数量不匹配

 

画图举例说明: 

第一种情况:数量顺序完全匹配时

第二种情况:数量匹配,顺序不匹配时 

 

第三种情况:数量不匹配时  

 

三、代码实现 

typedef char STDatyType;
typedef struct Stack
{STDatyType* a;int top;int capacity;}ST;
//栈的初始化
void STInit(ST* pst)
{assert(pst);pst->a = NULL;pst->top = pst->capacity = 0;//top指向栈顶元素的下一个位置}
void STDestroy(ST* pst)
{assert(pst);free(pst->a);pst->a = NULL;pst->top = pst->capacity = 0;}
void STPush(ST* pst, STDatyType x)
{assert(pst);if (pst->top == pst->capacity){int newcapacity=pst->capacity==0 ? 4 : pst->capacity * 2;STDatyType* tmp =(STDatyType*)realloc(pst->a, newcapacity * sizeof(STDatyType));if (tmp == NULL){perror("ralloc fail");return;}pst->capacity = newcapacity;pst->a = tmp;}pst->a[pst->top] = x;pst->top++;
}
//出栈
void STPop(ST* pst)
{assert(pst);assert(pst->top > 0);pst->top--;
}
//得到栈顶元素
STDatyType STTop(ST* pst)
{assert(pst);assert(pst->top > 0);return pst->a[pst->top - 1];
}
//判空
bool STEmpty(ST* pst)
{assert(pst);return pst->top == 0;
}
//获取数据个数
int STSize(ST* pst)
{assert(pst);return pst->top;
}bool isValid(char* s) 
{ST st;STInit(&st);while(*s){if(*s=='('||*s=='['||*s=='{'){STPush(&st,*s);}else//为右括号{if(STEmpty(&st)){STDestroy(&st);return false;}//栈不为空STDatyType top=STTop(&st);if(*s==')'&&top!='('||*s==']'&&top!='['||*s=='}'&&top!='{'){STDestroy(&st);return false;}//匹配然后出栈STPop(&st);}s++;}if(STEmpty(&st)){STDestroy(&st);return true;}else{STDestroy(&st);return false;}
}

 

 

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

相关文章:

  • 如何做网站水晶头贵阳网站建设运营
  • 郑州专业建站报价响应式布局模板
  • 网站的交互性专门学习网站建设读什么专业
  • 一个做礼品的网站怎么建立购物网站
  • 网站程序设计软件17一起来做网站
  • 开通网站主机logo是什么伊思logo
  • 创建一个网站的最常用的方法是先建立一个文件夹深圳哪家公司做网站好
  • 足球进球排行榜搜索引擎优化公司排行
  • 哪里有零基础网站建设教学中企动力z邮箱登录手机端
  • 做js题目的网站最新项目加盟代理
  • 网站seo优化8888网站html模板下载
  • 小时的网站建设定做小程序
  • 官方网站下载穿越火线网站建设业务员提成
  • 商务网站页面设计技术网站平台报价模板下载安装
  • 网站运营建设的目标线下编程课程收费标准
  • 惠州做网站哪家公司好易安卓开发app稳定吗
  • 海口建设工程信息网站网上做广告宣传
  • 具有品牌的常州做网站网站logo的作用
  • 门户网站 建设电商创客网站建设方案
  • 国外设计公司网站网线制作实验报告总结
  • 网站设计配色案列wordpress怎么新建子域名
  • 如何设置中国建设银行网站广告公司网站首页设计页面
  • 微网站开发流程网站建设要求说明
  • 园州网站建设制作网站公
  • 小企业做网站鹰潭网站设计
  • 知乎 闲鱼网站建设和网站运营有谁可以做网站寄生虫
  • 铜梁网站建设镇平网站建设
  • 网站服务商查询柳州专业网站优化
  • 外贸网站如何建设扁平化的网站有哪些
  • 多语言外贸网站开发网站建设 做个网上商城要多少钱啊