码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C. Good String(暴力枚举)


    Problem - 1389C - Codeforces

    题意:

    我们把某个字符串t1t2t3...tn-1tn的左循环移位称为字符串t2t3...tn-1tnt1。

    类似地,我们把字符串t的右循环移动称为字符串tnt1t2t3...tn-1。

    如果字符串t的左循环移位等于其右循环移位,我们就说它是好的。

    给你一个由数字0-9组成的字符串s。

    你需要从s中擦除多少个字符才能使其成为好字符串?

    输入
    第一行包含单个整数t(1≤t≤1000)--测试案例的数量。

    接下来的t行包含测试用例--每行一个。每个测试用例的第一行也是唯一一行包含字符串s(2≤|s|≤2⋅105)。每个字符si是数字0-9。

    保证字符串的总长度不超过2⋅105。

    输出
    对于每个测试案例,打印你需要从s中删除的最小字符数,以使其成为好的。
    题解:
    假设我们设这个字符串为奇数,长度为5

    原

    1 2 3 4 5

    2 3 4 5 1

    5 1 2 3 4

    2 = 5 

    3 = 1

    4 = 2

    5 = 3

    1 = 4

    我们发现如果长度为奇数,只有所有字母相同的情况下才会出现

    接着我们考虑偶数的情况

    1 2 3 4 

    2 3 4 1

    4 1 2 3

    2 = 4

    3 = 1

    4 = 2

    1 = 3

    发现只有下标为偶数时都相等,为奇数时都相等才行;

    为偶数时会有两种不同数字(相同的奇数n为奇数已经考虑了)

    那么我们暴力枚举所有(奇数位,偶数位)为两种数字的情况

    时间复杂度为9*9*2e5发现可以过

    1. #include<iostream>
    2. #include<cstring>
    3. #include<map>
    4. #include<algorithm>
    5. using namespace std;
    6. int n;
    7. char a[200050];
    8. int len1(int x,int y)
    9. {
    10. char o = x+'0';
    11. char p = y+'0';
    12. int f = 0;
    13. int cnt = 0;
    14. for(int i = 1;i <= n;i++)
    15. {
    16. if(a[i]==o&&f == 0)
    17. {
    18. f^=1;
    19. }
    20. if(a[i]==p&&f == 1)
    21. {
    22. f^= 1;
    23. cnt += 2;
    24. }
    25. }
    26. return cnt;
    27. }
    28. void solve()
    29. {
    30. cin >> a+1;
    31. n = strlen(a+1);
    32. map<int,int> vis;
    33. int ans = 0;
    34. for(int i = 1;i <= n;i++)
    35. {
    36. vis[a[i]-'0']++;
    37. ans = max(ans,vis[a[i]-'0']);
    38. }
    39. for(int i = 0;i <= 9;i++)
    40. {
    41. for(int j = 0;j <= 9;j++)
    42. {
    43. if(i == j)
    44. continue;
    45. ans = max(ans,len1(i,j));
    46. }
    47. }
    48. cout<<n-ans<<"\n";
    49. }
    50. int main()
    51. {
    52. int t;
    53. cin >> t;
    54. while(t--)
    55. {
    56. solve();
    57. }
    58. }

  • 相关阅读:
    GitOps 工具 Argo CD 实战教程
    lammps模拟激光加热案例
    数据处理:一维数组转成树状结构(递归和非递归),树状结构转成扁平化数组(递归和非递归)
    工程管理系统简介 工程管理系统源码 java工程管理系统 工程管理系统功能设计
    使用Java代码制作二维码(超级简单)
    flask 和fastdeploy 快速部署 yolov3
    Nanoprobes丨EnzMet 用于免疫组织化学 (IHC) 和印迹
    Cython 笔记 (Python/Jython)
    ESP8266-Arduino编程实例-LX1972可见光传感器驱动
    基于PHP的视频社交管理系统
  • 原文地址:https://blog.csdn.net/m0_64158084/article/details/127795608
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号