vijos 1379 字符串的展开

23333333333333333

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 1005000
char s[maxn],t[maxn],p[maxn];
int p1,p2,p3,top=-1,l;
void work(int x)
{
    int l=s[x-1],r=s[x+1],cnt=0;
    if ((s[x-1]<=‘9‘) && (s[x+1]>‘9‘)) {t[++top]=‘-‘;return;}
    if ((s[x-1]==‘-‘) || (s[x+1]==‘-‘)) {t[++top]=‘-‘;return;}
    for (int i=l+1;i<=r-1;i++)
    {
        for (int j=1;j<=p2;j++)
        {
            if (p1==3)
            {
                p[++cnt]=‘*‘;
                continue;
            }
            if ((s[x-1]>=‘0‘) && (s[x-1]<=‘9‘))
                p[++cnt]=i;
            else
            {
                if (p1==1) p[++cnt]=i;
                else if (p1==2) p[++cnt]=i-32;
            }
        }
    }
    if (p3==1)
    {
        for (int i=1;i<=cnt;i++)
            t[++top]=p[i];
    }
    else
    {
        for (int i=1;i<=cnt;i++)
            t[++top]=p[cnt-i+1];
    }
}
int main()
{
    scanf("%d%d%d",&p1,&p2,&p3);
    scanf("%s",s);
    l=strlen(s);
    for (int i=0;i<l;i++)
    {
        if (s[i]!=‘-‘)
            t[++top]=s[i];
        else
        {
            if (i==0) {t[++top]=‘-‘;continue;}
            if (i==l-1) {t[++top]=‘-‘;continue;}
            if (s[i-1]==s[i+1]) t[++top]=s[i];
            else if (s[i-1]>s[i+1]) t[++top]=s[i];
            else work(i);
        }
    }
    printf("%s",t);
    return 0;
}
时间: 2024-10-25 18:08:03

vijos 1379 字符串的展开的相关文章

洛谷 P1098 字符串的展开(NOIp2007提高组T2)

题目描述 在初赛普及组的"阅读程序写结果"的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于"d-h"或者"4-8"的字串,我们就把它当作一种简写,输出时,用连续递增的字母或数字串替代其中的减号,即,将上面两个子串分别输出为"defgh"和"45678".在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活.具体约定如下: (1) 遇到下面的情况需要做字符串的展开:在输入的字

字符串的展开

30:字符串的展开    总时间限制:1000ms  内存限制:65536kB描述    在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获数字串替代其中的减号,即,将上面两个子串分别输出为“defgh”和“45678”.在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活.具体约定如下:    (1) 遇到下面的情况需要做字符串的展开:在输入的字符串

洛谷 P1098 字符串的展开

题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母或数字串替代其中的减号,即,将上面两个子串分别输出为“defgh”和“45678”.在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活.具体约定如下: (1) 遇到下面的情况需要做字符串的展开:在输入的字符串中,出现了减号“-”,减号两侧同为小写字母或同为数字,且按照ASCII码的顺序,减号右

Luogu P1098 字符串的展开

一道很麻烦的模拟题. /* P1098 字符串的展开 * Au: GG */ #include <cstdio> #include <cstdlib> #include <cstring> #include <cmath> #include <cctype> #include <iostream> #include <algorithm> using namespace std; char s[103]; int n, p

NOIP2007字符串的展开

NOIP2007的第二道题目,个人感觉就是暴力去跑模拟就好了,数据范围是允许我们这样去跑程序的 题目简述:题目中会给你 三个关键字p1,p2,p3,对于不同的关键字会对你的程序提出要求,接下来会给你一个字符串,其中包含a-z,A-Z,0-9,以及减号-,我们需要做的就是按p1,p2,p3的要求对于“-”进行展开其中p1,p2,p3的具体要求如下: (1)遇到下面的情况需要做字符串的展开:在输入的字符串中,出现了减号“-”,减号两侧同为小写字母或同为数字,且按照ASCII 码的顺序,减号右边的字符

AC日记——字符串的展开 openjudge 1.7 35

35:字符串的展开 总时间限制:  1000ms 内存限制:  65536kB 描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获数字串替代其中的减号,即,将上面两个子串分别输出为“defgh”和“45678”.在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活.具体约定如下: (1) 遇到下面的情况需要做字符串的展开:在输入的字符串中,出现了

noip200706字符串的展开

试题描述: 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获数字串替代其中的减号,即,将上面两个子串分别输出为“defgh”和“45678”.在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活.具体约定如下: (1)遇到下面的情况需要做字符串的展开:在输入的字符串中,出现了减号“-”,减号两侧同为小写字母或同为数字,且按照ASCII码的顺序,减号右

洛谷1098 字符串的展开 解题报告

洛谷1098 字符串的展开 本题地址:http://www.luogu.org/problem/show?pid=1098 题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获数字串替代其中的减号,即,将上面两个子串分别输出为“defgh”和“45678”.在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活.具体约定如下:(1) 遇到下面的情

字符串的展开题目

题目描述 给定一个字符串,字符串包含数字.大小写字母以及括号(包括大括号,中括号,小括号),括号可以嵌套,即括号里面可以出现数字和括号. 按照如下规则对字符串进行展开,不需要考虑括号不成对的问题,不考虑数字后面没有括号的情况,即 2a2(b)不考虑. 数字表示括号里的字符串重复的次数,展开后的字符串不包含括号 将字符串进行逆序展开 123 输入abc2{de3[fg]} 输出gfgfgfedgfgfgfedcba 解法 利用栈进行计算,每次判断此时是否是右括号,如果是的话,拿到对应的左括号之前的