Ozon Tech Challenge 2020--B. Kuroni and Simple Strings(1200+构造双指针)

简介: 算法

20.png

题意:要求你从只含有()的字符串中删除一些使得剩下的字符串不会有成括号的情况。

思路:从左边开始找(,从右边开始找),优先匹配,不行则停止。

#include<bits/stdc++.h>
using namespace std;
const int maxn=10005;
int sum1[maxn],sum2[maxn];
char s1[maxn];
int ans1[maxn];
int main()
{
    int n,i,j,t;
    cin>>(s1+1);
    for(i=1;i<strlen(s1+1);i++)
    {
        if(s1[i]=='(')
            sum1[i]=sum1[i-1]+1,sum2[i]=sum2[i-1];
        else
            sum2[i]=sum2[i-1]+1,sum1[i]=sum1[i-1];
    }
    int l=1,r=strlen(s1+1),ans=0,idx=0,cnt=0,flag=0;
    while(l<=r)
    {
        if(flag==0)
        {
            if(s1[l]=='(')
            {
                flag=l;
            }
            l++;
        }
        else
        {
            if(s1[r]==')')
            {
                ans1[cnt++]=flag;
                ans1[cnt++]=r;
                ans++;
                flag=0;
            }
            r--;
        }
        //cout<<l<<" "<<r<<" "<<flag<<" "<<ans<<endl;
    }
    if(ans>0)
    {
        cout<<1<<endl<<2*ans<<endl;
        sort(ans1,ans1+cnt);
        for(i=0;i<cnt;i++) cout<<ans1[i]<<" ";
        cout<<endl;
    }
    else
        cout<<0<<endl;
    return 0;
}
相关文章
|
9月前
|
存储 编译器 C++
C++:this指针和构造与析构的运用--2
C++:this指针和构造与析构的运用--2
|
9月前
复制带随机指针的链表【构造链表深拷贝】
复制带随机指针的链表【构造链表深拷贝】
|
9月前
|
存储 C++
C++:this指针和构造与析构的运用--3
C++:this指针和构造与析构的运用--3
|
9月前
|
存储 编译器 C++
C++:this指针和构造与析构的运用--1
C++:this指针和构造与析构的运用--1
|
存储 编译器 C语言
【C++学习】类和对象 | 类的成员函数存放在哪里?| this指针 | 构造函数 | 析构函数 | 探索构造和析构函数的更多细节
【C++学习】类和对象 | 类的成员函数存放在哪里?| this指针 | 构造函数 | 析构函数 | 探索构造和析构函数的更多细节
255 0
|
数据建模
【每日一题Day66】LC1754构造字典序最大的合并字符串 | 贪心 双指针模拟
思路:双指针遍历两个字符串,贪心比较字符的字典顺序,并添加至结果集
85 0
【每日一题Day66】LC1754构造字典序最大的合并字符串 | 贪心 双指针模拟
codeforces1509 D. Binary Literature (构造+指针)
codeforces1509 D. Binary Literature (构造+指针)
83 0
|
3月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
267 13
|
4月前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
56 0
|
5月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。
201 4

热门文章

最新文章