练习时长的代码练习生
练习时长的代码练习生
全部文章
分类
归档
标签
去牛客网
登录
/
注册
练习时长的代码练习生的博客
全部文章
(共10篇)
题解 | #把数字翻译成字符串#
class Solution { public: int solve(string nums) { if(...
字符串
动态规划
C
C++
2022-08-14
0
355
题解 | #翻转单词序列#
class Solution { public: string ReverseSentence(string str) { &nb...
字符串
C++
栈
2022-07-28
0
310
题解 | #正则表达式匹配#
C排名第一,该题是《HJ71 字符串通配符》的简化版本。不用动态规划和递归,用双指针回溯法,只遍历一次,不占用额外空间。由于模式串中的字符 '*' 表示它前面的字符可以出现任意次,为了方便处理 '*' 和它前面的字符,在这里逆序匹配字符。 思路: 指针 i,j 分别表示 str...
字符串
双指针
回溯
C
C++
2022-07-10
0
264
题解 | #字符串通配符#
递归的时间复杂度太大了,字符串稍微复杂且长度超过50就容易超时。我参考了C排名第一的代码(有bug:a* a##### 运行为true,且会匹配到最后,正确答案为false),并进行了优化。 思路: 用指针记录当前’*‘的位置与当前匹配字符的位置(开始时'*'的匹配数为0),按匹配规则继...
字符串
回溯
字符串匹配
递归
C
C++
2022-07-09
2
323
题解 | #四则运算#
难点在于判断输入的数字是否为负数和运算符优先级。 可以在一次循环中以获取一个数字+ 一个运算符+括号(如果有)为准则 ,如果在这次循环中先遇到‘-’号,则将它与后面的数视为负数而不是将‘-’视为减号。 在遇到运算符入栈时,要判断符号优先级,只要不高于栈顶符号优先级就先把栈顶符号取出计算,...
数组
字符串
栈
字符串匹配
C
2022-06-24
0
415
题解 | #尼科彻斯定理#
m^2即为中位数(平均数),找到中位数后,再找第一个数n,可以推导出n,最后化简得到n=m^2-m+1,以2为步长依次输出其后的m-1个数 #include <stdio.h> int main(){ &...
数组
字符串
C
C++
2022-06-24
0
473
题解 | #配置文件恢复#
比较容易想到的办法:取输入字符串第一行和第二行分别与命令串比较,判断是不是其前缀子串。再统计匹配成功次数,成功两次且唯一就输出。 也是因为对C库函数不太了解的原因,老老实实做的,代码写得太多了,最开始的命令串声明改成二维数组存储,代码量会少很多。 /*只能判断串中间最多只有一个空格的字符串...
数组
字符串
字符串匹配
C
2022-06-22
0
315
题解 | #火车进站#
方法一:暴力搜索。 比较容易想到,先按照全排列的方法,找出火车进站序列的全排列。从全排列序列中找到符合出站规则的序列,再将所有的合法序列排序,最后依次打印输出。 出站规则:用栈储存入站火车序号,另一边用一个指针顺序遍历当前的全排列序列,对比当前栈顶序号是否与指针所指的全排列序列号相等。 ...
数组
字符串
深度优先搜索
栈
回溯
计数
递归
快速选择
C
C++
2022-06-21
11
1235
题解 | #最长回文子串#
不懂怎样才能写出时间复杂度为O(n),我只能写O(n^2) #include <stdio.h> #include <string.h> int main(){ char s[350]=...
数组
字符串
双指针
C
2022-06-16
0
386
题解 | #自动售货系统#
一遍过,用的笨方法写,部分代码可以优化,逻辑都挺简单的,就是题目要求多且复杂,代码运行时空效率都还可以 #include <stdio.h> #include <string.h> #define goods_nums 6//定义商品种...
数组
字符串
设计
模拟
计数
字符串匹配
交互
计数排序
C
2022-06-15
0
711