Pta L1-058 6翻了

简介: 输入在一行中给出一句话,即一个非空字符串,由不超过 1000 个英文字母、数字和空格组成,以回车结束。

94c51cd1060c2735b5990a959087d3a3.jpg

“666”是一种网络用语,大概是表示某人很厉害、我们很佩服的意思。最近又衍生出另一个数字“9”,意思是“6翻了”,实在太厉害的意思。如果你以为这就是厉害的最高境界,那就错啦 —— 目前的最高境界是数字“27”,因为这是 3 个 “9”!


本题就请你编写程序,将那些过时的、只会用一连串“6666……6”表达仰慕的句子,翻译成最新的高级表达。


输入格式:

输入在一行中给出一句话,即一个非空字符串,由不超过 1000 个英文字母、数字和空格组成,以回车结束。


输出格式:

从左到右扫描输入的句子:如果句子中有超过 3 个连续的 6,则将这串连续的 6 替换成 9;但如果有超过 9 个连续的 6,则将这串连续的 6 替换成 27。其他内容不受影响,原样输出。


输入样例:

it is so 666 really 6666 what else can I say 6666666666

输出样例:

it is so 666 really 9 what else can I say 27


#include <stdio.h>
#include <string.h>
int main()
{
  char str[66] = { 0 };
  scanf("%[^\n]s", str);    // 这种写法输入可以输入到\n停止,但不接受\n
  int flag = 0;
  int count = 0;
  int len = strlen(str);
  //it is so 666 really 6666 what else can I say 666666666666666 and hehe.
  //it is so 666 really 9 what else can I say 27
  char* pc = str;
  for (int i = 0; i < len; i++, pc++)
  {
    if (str[i] == '6')
    {
      count++;
      if (count > 3 && count < 9)    //你可能会问为什么strcpy内容不写在这里
      {                              //因为3以上和9以上,一但是9以上,三以上
        flag = 1;                  //也要执行,但我们只想让9以上执行
      }
      else if (count > 9)
      {
        flag = 2;
      }
    }
    else
    {
      if (flag == 1)
      {
        *(pc - 1) = '9';            // 这里调试一下就看的到位置了
        strcpy(pc - count, pc - 1); // 因为这里要等count == 4 的下一次
        flag = 0;                   // 循环才会执行,所以pc指向我们所要
      }                               // 内容的下一个
      else if (flag == 2)
      {
        *(pc - 1) = '7';            // 这里同理
        *(pc - 2) = '2';
        strcpy(pc - count, pc - 2);       
        flag = 0;
      }
      else
        ;
      count = 0;
    }
  }
  printf("%s", str);
  return 0;
}

这种写法空间复杂度为O(1),当然还有用空间复杂度为O(n)的做法,但和上述做法大差不差,只是strcpy不是复制在原数组当中了,而且修改9和27也可以简便一点。

目录
相关文章
|
2月前
|
机器学习/深度学习 算法
小小GCD、LCM拿下拿下
小小GCD、LCM拿下拿下
|
7月前
|
机器学习/深度学习 索引
PTA-猴子选大王
程序模拟了猴子报数选猴王的过程,初始有N只猴子(N≤1000),从1号开始按1到3报数,报到3的猴子退出,直至只剩一只猴子,该猴子成为猴王。输入示例为11,输出示例为7。代码通过初始化猴子列表和当前报数索引,不断移除报数为3的猴子,最后返回剩余猴子的编号。
49 0
|
6月前
|
算法
【牛客周赛Round 27】题目讲解
【牛客周赛Round 27】题目讲解
|
6月前
OJ刷题:猜名次和找凶手
OJ刷题:猜名次和找凶手
35 0
|
7月前
|
C++
【PTA】L1-019 谁先倒 (C++)
【PTA】L1-019 谁先倒 (C++)
93 0
【PTA】L1-019 谁先倒 (C++)
|
7月前
|
C++
【PTA】​L1-058 6翻了 ​ (C++)
【PTA】​L1-058 6翻了 ​ (C++)
81 0
【PTA】​L1-058 6翻了 ​ (C++)
|
7月前
|
C++
【PTA】L1-020 帅到没朋友 (C++)
【PTA】L1-020 帅到没朋友 (C++)
121 0
【PTA】L1-020 帅到没朋友 (C++)
|
7月前
蓝桥备战--分糖果OJ2928 贪心 分类讨论
蓝桥备战--分糖果OJ2928 贪心 分类讨论
72 0