Time Limit: 1 second

Memory Limit: 50 MB

【问题描述】

  1. 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获数字串替代其中的减号,即,将上面两个子串分别输出为“defgh”和“45678”。在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活。具体约定如下:
  2. (1) 遇到下面的情况需要做字符串的展开:在输入的字符串中,出现了减号“-”,减号两侧同为小写字母或同为数字,且按照ASCII码的顺序,减号右边的字符严格大于左边的字符。
  3. (2) 参数p1:展开方式。p1=1时,对于字母子串,填充小写字母;p1=2时,对于字母子串,填充大写字母。这两种情况下数字子串的填充方式相同。p1=3时,不论是字母子串还是数字字串,都用与要填充的字母个数相同的星号“*”来填充。
  4. (3) 参数p2:填充字符的重复个数。p2=k表示同一个字符要连续填充k个。例如,当p2=3时,子串“d-h”应扩展为“deeefffgggh”。减号两边的字符不变。
  5. (4) 参数p3:是否改为逆序:p3=1表示维持原来顺序,p3=2表示采用逆序输出,注意这时候仍然不包括减号两端的字符。例如当p1=1p2=2p3=2时,子串“d-h”应扩展为“dggffeeh”。
  6. (5) 如果减号右边的字符恰好是左边字符的后继,只删除中间的减号,例如:“d-e”应输出为“de”,“3-4”应输出为“34”。如果减号右边的字符按照ASCII码的顺序小于或等于左边字符,输出时,要保留中间的减号,例如:“d-d”应输出为“d-d”,“3-1”应输出为“3-1”。

【输入】

  1. 2行;
  2. 1行为用空格隔开的3个正整数,一次表示参数p1p2p3
  3. 2行为一行字符串,仅由数字、小写字母和减号“-”组成。行首和行末均无空格。

【输出】

  1. 只有一行,为展开后的字符串。

【输入样例1】

  1. 1 2 1
  2. abcs-w1234-9s-4zz

【输出样例1】

  1. abcsttuuvvw1234556677889s-4zz

【输入样例2】

  1. 2 3 2
  2. a-d-d

【输出样例2】

  1. aCCCBBBd-d

【输入样例3】

  1. 3 4 2
  2. di-jkstra2-6

【输出样例3】

  1. dijkstra2************6

【 限制】

  1. 40%的数据满足:字符串长度不超过5
  2. 100%的数据满足:1<=p1<=31<=p2<=81<=p3<=2。字符串长度不超过100

【题目链接】:http://noi.qz5z.com/viewtask.asp?id=b702

【题解】



就模拟搞一搞;

algorithm里面有reverse这个翻转字符串的函数;很方便哦;

每次修改了;让指针再变回1就好了;当然不变也可以就now++就好;

随便你了;(因为字符串最长100我才敢这么任性的!)



【完整代码】

  1. #include <cstdio>
  2. #include <algorithm>
  3. #include <string>
  4. #include <iostream>
  5. using namespace std;
  6. int p1,p2,p3;
  7. string s;
  8. int lx(char x)
  9. {
  10. if (isdigit(x))
  11. return 1;
  12. else
  13. if (x!='-')
  14. return 0;
  15. else
  16. return -1;
  17. }
  18. int main()
  19. {
  20. //freopen("F:\\rush.txt","r",stdin);
  21. scanf("%d%d%d",&p1,&p2,&p3);
  22. cin >> s;
  23. int now = 1,len = s.size();
  24. while (now <= len-2)
  25. {
  26. if (s[now]=='-')
  27. {
  28. int lx1 = lx(s[now-1]),lx2 = lx(s[now+1]);
  29. if (lx1!=-1 && lx1==lx2 && s[now-1]<s[now+1])
  30. {
  31. if (s[now-1] == s[now+1]-1)
  32. {
  33. s.erase(now,1);
  34. now = 1;
  35. }
  36. else
  37. {
  38. string temp="";
  39. for (char t = s[now-1]+1;t<=s[now+1]-1;t++)
  40. {
  41. for (int i = 1;i <=p2;i++)
  42. temp+=t;
  43. }
  44. if (p3==2)
  45. reverse(temp.begin(),temp.end());
  46. int le = temp.size();
  47. if (p1==2 && !isdigit(temp[0]))
  48. for (int i = 0;i <= le-1;i++)
  49. temp[i] = temp[i]-'a'+'A';
  50. if (p1==3)
  51. for (int i = 0;i <= le-1;i++)
  52. temp[i] = '*';
  53. s.erase(now,1);
  54. s.insert(now,temp);
  55. now = 1;
  56. }
  57. }
  58. else
  59. now++;
  60. }
  61. else
  62. now++;
  63. len = s.size();
  64. }
  65. cout << s << endl;
  66. return 0;
  67. }

【b702】字符串的展开的更多相关文章

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

    35:字符串的展开 总时间限制:  1000ms 内存限制:  65536kB 描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h ...

  2. TYVJ P1053 字符串的展开 Label:字符 水

    背景 NOIP2007年提高组第2道 描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或“4-8”的子串,我们就把它当作一种简 ...

  3. Luogu 1098 - 字符串的展开 - [字符串操作][模拟]

    题目链接:https://www.luogu.org/problemnew/show/P1098 题目描述在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中 ...

  4. 洛谷P1098 字符串的展开【字符串】【模拟】

    题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母或数 ...

  5. C语言 · 字符串的展开

     算法训练 字符串的展开   时间限制:1.0s   内存限制:256.0MB      在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d ...

  6. noip200706字符串的展开

    试题描述: 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获 ...

  7. 洛谷 P1098 字符串的展开

    题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母或数 ...

  8. 洛谷P1098 字符串的展开

    P1098 字符串的展开 题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输 ...

  9. 洛谷——P1098 字符串的展开

    P1098 字符串的展开 题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输 ...

随机推荐

  1. 洛谷 P1757 通天之分组背包

    P1757 通天之分组背包 题目背景 直达通天路·小A历险记第二篇 题目描述 自01背包问世之后,小A对此深感兴趣.一天,小A去远游,却发现他的背包不同于01背包,他的物品大致可分为k组,每组中的物品 ...

  2. RK3066 实现LED闪烁的代码分析

    实现LED灯的闪烁,须要在驱动里加入一个定时器函数,详细实现涉及到了LED GPIO驱动.用户空间程序调用驱动程序. 1.首先来看LED设备驱动注冊过程,代码位于../kernel/drivers/l ...

  3. 深度学习 Deep LearningUFLDL 最新Tutorial 学习笔记 2:Logistic Regression

    1 Logistic Regression 简述 Linear Regression 研究连续量的变化情况,而Logistic Regression则研究离散量的情况.简单地说就是对于推断一个训练样本 ...

  4. $.post()提交了数据,return不给跳转

    本来Controller接到普通请求,return “somePage”,这样就跳转了.前台用$.post()提交了数据(不需要回调),我了个大草,return那里就不给跳转了这样怎么解决? ajax ...

  5. ubuntu14.04 printk()默认打印的位置

    tail /var/log/syslog 即可显示printk打印的信息

  6. JavaScript--数据结构与算法之排序

    排序总结————常见的排序 常见的9中排序(冒泡,选择,插入(二分插入,希尔),归并,快速,堆,计数,基数,桶排序)可分为两类 比较排序:冒泡,选择,插入(二分插入,希尔),归并,堆,快速 非比较排序 ...

  7. BZOJ2565: 最长双回文串(Manacher)

    Description 顺序和逆序读起来完全一样的串叫做回文串.比如acbca是回文串,而abc不是(abc的顺序为“abc”,逆序为“cba”,不相同).输入长度为n的串S,求S的最长双回文子串T, ...

  8. SSO单点登录学习总结(1)——单点登录(SSO)原理解析

    SSO的概念: 单点登录SSO(Single Sign-On)是身份管理中的一部分.SSO的一种较为通俗的定义是:SSO是指访问同一服务器不同应用中的受保护资源的同一用户,只需要登录一次,即通过一个应 ...

  9. [Vue + TS] Using Route events inside Vue

    vue-router introduces new hooks into the component. In this lesson we’ll show you how to use these n ...

  10. docker进入容器的几种方法

    一 启动进入容器指定bash 退出后容器关闭 [root@Centos-node3 ~]# docker run -it centos bash [root@83c6b25aca09 /]# 二 do ...