(数据结构整理)NJUPT1054
这一篇博客以一些OJ上的题目为载体,整理一下数据结构。会陆续的更新。
。。
我们都知道,数据结构的灵活应用有时能让简化一些题目的解答。
一、栈的应用
1、NJUPT OJ 1054(回文串的推断)
回文串的推断:将一个字符串的一半存入一个栈中。然后从栈顶開始推断这个字符串是否是回文串
- /*
- * NJUPTOJ_1054.cpp
- *
- * Created on: 2014年5月22日
- * Author: pc
- */
- #include <iostream>
- #include <cstdio>
- using namespace std;
- const int maxn = 300;
- void toLower(char arr[],int len){
- int i;
- for(i = 0 ; i < len ; ++i){
- if(!islower(arr[i])){
- arr[i] += 32;
- }
- }
- }
- int main(){
- char a[maxn];
- char s[maxn];
- while(gets(a)!=NULL){
- int len = strlen(a);
- toLower(a,len);
- int mid = len/2 - 1;
- int top = 0;
- int i;
- for(i = 0 ; i <= mid ; ++i){
- s[++top] = a[i];
- }
- int next;
- if(len%2 == 0){
- next = mid+1;
- }else{
- next = mid+2;
- }
- for(i = next ; i <= len-1 ; ++i){
- if(s[top] != a[i]){
- break;
- }
- --top;
- }
- if(top != 0){
- printf("Not Palindrome.\n");
- }else{
- printf("Bingle! Palindrome.\n");
- }
- }
- return 0;
- }
下面是再次做这道题时的代码:
- /*
- * njupt_1054_1.cpp
- *
- * Created on: 2014年9月6日
- * Author: pc
- */
- #include <iostream>
- #include <cstdio>
- using namespace std;
- const int maxn = 300;
- /**
- * 将一个字符串转化成小写
- */
- void toLower(char a[]){
- int len = strlen(a);
- int i;
- for(i = 0 ; i < len ; ++i){
- if(islower(a[i]) == false){
- a[i] += 32;
- }
- }
- }
- void work(char a[]){
- int len = strlen(a);
- int s[len];
- /**
- *关于mid和next额理解:
- *mid: 用来标记開始比較时栈顶的第一个元素
- *next: 用来比較剩下的一半的字符串中開始比較时的第一个元素的位置
- */
- int mid = len/2 - 1;
- int next;
- if(len%2 == 0){
- next = mid+1;
- }else{
- next = mid+2;
- }
- int top = 0;
- int i;
- for(i = 0 ; i <= mid ; ++i){
- s[++top] = a[i];
- }
- for(i = next ; i <= len-1 ; ++i){
- if(s[top] != a[i]){
- break;
- }
- --top;
- }
- if(top == 0){
- printf("Bingle! Palindrome.\n");
- }else{
- printf("Not Palindrome.\n");
- }
- }
- int main(){
- char s[maxn];
- /**
- * 不知道行数时的输入的处理方式...
- */
- while(gets(s) != NULL){
- toLower(s);
- work(s);
- }
- return 0;
- }
2、NEFU OJ 194 回文字符串
算法思想和上面的是一样的
- /*
- * NEFU_194.cpp
- *
- * Created on: 2014年5月23日
- * Author: pc
- */
- #include <iostream>
- #include <cstdio>
- using namespace std;
- string a;
- string s;
- int main() {
- int t;
- scanf("%d", &t);
- while (t--) {
- cin >> a;
- int len = a.length();
- int mid = len / 2 - 1;
- int top = 0;
- int i;
- for (i = 0; i <= mid; ++i) {
- top += 1;
- s[top] = a[i];
- }
- int next;
- if (len % 2 == 0) {
- next = mid + 1;
- } else {
- next = mid + 2;
- }
- for (i = next; i <= len - 1; ++i) {
- if (s[top] != a[i]) {
- break;
- }
- --top;
- }
- if (top != 0) {
- printf("NO\n");
- } else {
- printf("YES\n");
- }
- }
- return 0;
- }
3、NYOJ 1002 括号的匹配
思想:假设输入的符号是(、[则直接进栈,假设是],则推断此事最后一个是否是[,假设是[出栈,否则]进栈
- /*
- * NY_2_1.cpp
- *
- * Created on: 2014年5月25日
- * Author: pc
- */
- #include <iostream>
- #include <cstdio>
- #include <stack>
- using namespace std;
- int main(){
- string a;
- int t;
- scanf("%d",&t);
- while(t--){
- stack<char> s;
- cin >> a;
- int len = a.length();
- int i;
- for(i = 0 ; i < len ; ++i){
- if(a[i] == '(' || a[i] == '['){
- s.push(a[i]);
- }else if(a[i] == ')'){
- if(!s.empty() && s.top() == '('){
- s.pop();
- }else{
- s.push(a[i]);
- }
- }else if(a[i] == ']'){
- if(!s.empty() && s.top() == '['){
- s.pop();
- }else{
- s.push(a[i]);
- }
- }
- }
- if(s.empty()){
- printf("Yes\n");
- }else{
- printf("No\n");
- }
- }
- return 0;
- }
(数据结构整理)NJUPT1054的更多相关文章
- 转 Python常见数据结构整理
http://www.cnblogs.com/jeffwongishandsome/archive/2012/08/05/2623660.html Python常见数据结构整理 Python中常见的数 ...
- Java数据结构整理(一)
ava数据结构内容整理关键字: 数据结构 Collection:List.SetMap:HashMap.HashTable如何在它们之间选择一.Array , ArraysJava所有“存储及随机访问 ...
- redis数据结构整理(二)
摘要: 1.各个数据结构的应用举例 1.1 String类型应用举例 1.2List类型应用举例 1.3Set类型应用举例 1.4Sorted Set类型应用举例 1.5Hash类型应用举例 内容: ...
- redis数据结构整理(一)
摘要: 0.redis安装 1.redis的常用数据结构类型 1.1 String 1.2 List 1.3 Set 1.4 Sorted Set 1.5 Hash 2.redis是单进程单 ...
- C++ 基本数据结构整理
Hash Map (Unordered_map) Insert #include <unordered_map> using namespace std; unordered_map &l ...
- java数据结构整理(二)
一.List接口,有序的Collection接口,能够精确地控制每个元素插入的位置,允许有相同的元素 1.链表,LinkedList实现了List接口,允许null元素,提供了get().remove ...
- Python常见数据结构整理
Python中常见的数据结构可以统称为容器(container).序列(如列表和元组).映射(如字典)以及集合(set)是三类主要的容器. 一.序列(列表.元组和字符串) 序列中的每个元素都有自己的编 ...
- java常见数据结构整理
java中容器类数据结构主要在java.util包中. java.util包中三个重要的接口及特点:List(列表).Set(保证集合中元素唯一).Map(维护多个key-value键值对,保证key ...
- acm数据结构整理
一.区间划分 //区间划分+持久化并查集:区间连通情况统计. inline bool comp(Ask x, Ask y){return x.km == y.km ? x.l > y.l : x ...
随机推荐
- Mybatis解决了JDBC编程哪些问题
一:Mybatis简介 MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动.创建connection.创 ...
- linux下使用DBCA(database configuration assistant)创建oracle数据库
前提:切换到图形界面 到Oracle的bin文件夹下,使用oracle用户.运行dbca就可以.和windows的效果一样. 假设出现乱码 export LANG="en_US:UTF-8& ...
- 带输出參数的存储过程的定义,以及在aso.net中调用
ALTER proc [dbo].[mp_w_RechargePortalPayPal_All] ( @PayPalOrderNo nvarchar(50), --订单号 @nAccountIDFro ...
- 根据数据表自动生成javaBean
package fanshe; import java.io.File; import java.io.FileWriter; import java.io.IOException; import j ...
- org.hibernate.AssertionFailure: null id in com.you.model.User entry (don't flush the Session after a
1.错误描写叙述 org.hibernate.AssertionFailure: null id in com.you.model.User entry (don't flush the Sessio ...
- 【Bootstrap】一个PC、平板、手机同一时候使用并且美观的登陆页面
Bootstrap如同前台框架,它已经布置好不少的CSS.前端开发的使用须要则直接调用就可以.其站点的网址就是http://www.bootcss.com.使用Bootstrap能降低前端开发时候在C ...
- bzoj1019: [SHOI2008]汉诺塔(动态规划)
1019: [SHOI2008]汉诺塔 题目:传送门 简要题意: 和经典的汉诺塔问题区别不大,但是题目规定了一个移动时的优先级: 如果当前要从A柱子移动,但是A到C的优先级比A到B的优先级大的话,那就 ...
- ANSI编码
ANSI编码 ANSI简介 不同的国家和地区制定了不同的标准,由此产生了 GB2312.GBK.Big5.Shift_JIS 等各自的编码标准.这些使用 1 至 4 个字节来代表一个字符的各种汉字延伸 ...
- javascript系列-class9.DOM(上)
欢迎加入前端交流群交流知识获取视频资料:749539640 1.文档对象模型DOM(document Object Model) 所谓DOM就是以家族的形式描述HTML 节点 ...
- [codeforces 1037D] Valid BFS? 解题报告(验证bfs序,思维题)
题目链接:http://codeforces.com/problemset/problem/1037/D 题目大意: 给出一棵树,询问一个序列是否可能为这棵树从节点1开始遍历的bfs序 题解: 对于每 ...