AB串
题目:
给定n个A和2n个B。用这些字符拼成一个字符串。要求这个串的全部前缀和后缀B的个数始终不少于A。
(一个字符串的前缀是仅仅从开头到某个位置为止的子串,后缀是仅仅从某个位置到结尾的子串)。
输入格式
多组数据。每组数据仅仅有一行,包括一个正整数n。
(n<=10^17)。
输出格式
每组数据输出一行,终于结果对99991取余数的结果。
分析:
简单的想法是建立一个二叉树。深度遍历一下就可以。
可是效率太低,对照较大的n不太适用,临时没想到什么好办法。先简单的做做看。
代码:
<span style="font-size:18px;">#include <stdio.h>
#include <stdlib.h> struct Node {
int value;
struct Node *left;
struct Node *right;
}; #define n 3
static int result = 0;
static int index = 0;
static int array[3 * n] = {0}; struct Node* initNode()
{
struct Node* temp = (struct Node *)malloc(sizeof(struct Node));
temp->value = 0;
temp->left = NULL;
temp->right = NULL;
return temp;
} void creatTree(struct Node* parent, int a, int b)
{
if (a > 0)
{
struct Node* left = initNode();
left->value = -1;
parent->left = left;
creatTree(left, a - 1, b);
}
if (b > 0)
{
struct Node* right = initNode();
right->value = 1;
parent->right = right;
creatTree(right, a, b - 1);
}
if (a <= 0 && b <=0)
{
return;
}
} //static int array[100] = {0}; void dfs(struct Node* root, int sum)
{
int i = 0;
if (root == NULL)
{
//result++;
return;
} if (root->value == 1 && root->left == NULL && root->right == NULL)
{
result++;
printf("%d\n", root->value);
printf("\nget one\n");
return;
} sum += root->value; if (sum < 0 || sum > n)
{
return;
}
else
{
printf("%d\n", root->value);
//index = 0;
dfs(root->left, sum);
dfs(root->right, sum);
} } void freeNode(struct Node* root)
{
if (root != NULL)
{
//printf("%d\n", root->value);
//printf("%d\n", root->left->value);
freeNode(root->left);
freeNode(root->right);
free(root);
}
return;
} int main()
{
int a = 0, b = 0, sum = 0;
a = n;
b = n * 2; /* 根节点 B */
struct Node *root = initNode();
root->value = 1; /* 建立二叉树 */
creatTree(root, a, b-1); /* 深度搜索遍历法得到结果 */
dfs(root, sum);
printf("result = %d\n", result); /* 释放内存 */
freeNode(root);
return 0;
}
</span>
AB串的更多相关文章
- AB串(上帝都不会,我就没救了)
[题目分析] 设答案的长度为m,
- 数据结构(三)串---KMP模式匹配算法
(一)定义 由于BF模式匹配算法的低效(有太多不必要的回溯和匹配),于是某三个前辈发表了一个模式匹配算法,可以大大避免重复遍历的情况,称之为克努特-莫里斯-普拉特算法,简称KMP算法 (二)KMP算法 ...
- Codeforces 划水
Codeforces 566F 题目大意:给定$N$个数,任意两个数之间若存在一个数为另一个数的因数,那么这两个数存在边,求图中最大团. 分析:求一个图最大团为NP-Hard问题,一般不采用硬方法算. ...
- BZOJ 3160: 万径人踪灭
Description 一个ab串,问有多少回文子序列,字母和位置都对称,并且不连续. Sol FFT+Manacher. 不连续只需要减去连续的就可以了,连续的可以直接Manacher算出来. 其他 ...
- Hackerrank11 LCS Returns 枚举+LCS
Given two strings, a and , b find and print the total number of ways to insert a character at any p ...
- POJ 3415 后缀数组
题目链接:http://poj.org/problem?id=3415 题意:给定2个串[A串和B串],求两个串公共子串长度大于等于k的个数. 思路:首先是两个字符串的问题.所以想用一个'#'把两个字 ...
- poj3415
很久以前写的,忘补结题报告了两串相连中间用特殊的分隔符然后求height,由于要求求公共子串大于等于k的个数,并且只要位置不同即可因此不难想到在名次上对height分组,一组内的height保证> ...
- Codeforces - ZeptoLab Code Rush 2015 - D. Om Nom and Necklace:字符串
D. Om Nom and Necklace time limit per test 1 second memory limit per test 256 megabytes input standa ...
- UVALive 5792 Diccionário Portuñol
字符串匹配问题 有n个a串个m个b串,讲a的前缀和b的后缀粘在一起有多少个不同的新串. 首先求不同的前缀和后缀肯定好求了,就用字典树分别存一下a个倒过来的b. 那个问题就是解决例如,abcd,和bcd ...
随机推荐
- C#脏字过滤算法
public class DirtyWordOper { private static Dictionary<string, object> hash = new Di ...
- java面向对象的构造函数
当使用new来创建一个对象的时候,其实是调用了一个函数,这个函数的名称叫做构造函数 构造函数的特点: 1.构造函数的名称必须和类名完全一致,包括大小写. 2.构造函数不写返回值,不写返回值意味着连vo ...
- [转载] 《Hadoop基础教程》之初识Hadoop
转载自http://blessht.iteye.com/blog/2095675 Hadoop一直是我想学习的技术,正巧最近项目组要做电子商城,我就开始研究Hadoop,虽然最后鉴定Hadoop不适用 ...
- 关于web变量配置问题
关于web变量配置问题 webservice里面接口完成时考虑到接口可能用在不同的服务器,不同的数据库所以将链接地址修改成变量,在webconfig里面去修改它更加的容易方便 假始根据在同一个服务器里 ...
- 模仿J2EE的session机制的App后端会话信息管理
此文章只将思想,不提供具体完整实现(博主太懒,懒得整理),有疑问或想了解的可以私信或评论 背景 在传统的java web 中小型项目中,一般使用session暂存会话信息,比如登录者的身份信息等.此机 ...
- 赢在面试之Java泛型篇(十二)
139. Java中的泛型是什么 ? 使用泛型的好处是什么? 泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数. 好处: 1.类型安全,提供编译期 ...
- Spring4 事务管理
Spring4 事务管理 本章是Spring4 教程中的最后一章,也是非常重要的一章.如果说学习IOC是知识的入门,那学习事务管理就是知识的提升.本章篇幅可能有一丢丢长,也有一丢丢难,需要读者细细品味 ...
- AIO5系统中-打印样式常见问题处理
1.为什么我的报表没有数据显示? 答:请看一下报表是否有绑定数据源,有添加查询,如果这些都做了,请看下主项数据的数据源有没有绑定,这些都绑定了,就会有数据的显示. 2.为什么我做的报表分组很乱? 答: ...
- 将下载到本地的JAR包手动添加到Maven仓库
<!-- https://mvnrepository.com/artifact/ojdbc/ojdbc --><!-- (参数一):下载到本地的ojdbc-10.2.0.4.0.ja ...
- JavaWeb框架SSH_Struts2_(三)
1. Struts2的拦截器(使用拦截器实现权限控制) 拦截器简介 拦截器概述 拦截器工作原理 拦截器的配置 Struts2的内建拦截器 内建拦截器的介绍 内建拦截器的配置 自定义拦截器 实现自定义拦 ...