2023-11-29:用go语言,给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。

需保证 返回结果的字典序最小。

要求不能打乱其他字符的相对位置)。

输入:s = "cbacdcbc"。

输出:"acdb"。

来自左程云

答案2023-11-29:

所有的代码用灵捷3.5编写,感觉有点抽风了,生成的代码需要修改才能运行。

大体过程如下:

1.初始化一个长度为 26 的整数数组 cnts,用于记录字符串中每个字母出现的次数。

2.初始化一个长度为 26 的布尔数组 enter,用于标记字母是否已经入栈。

3.遍历字符串 s 中的每个字符,统计每个字母出现的次数,并更新到 cnts 数组中。

4.初始化一个长度为 26 的字节数组 stack 作为栈,用于存储最终的结果。

5.初始化一个整数变量 size,表示当前栈的大小,初始值为 。

6.遍历字符串 s 中的每个字符:

6.1.将当前字符存储在变量 cur 中。

6.2.如果 cur 还未入栈,则执行以下操作:

6.2.1.判断栈是否为空或者栈顶元素小于等于 cur,或者栈顶元素在剩余字符中不再出现时退出循环。

6.2.2.将栈顶元素标记为未入栈(即 enter[stack[size-1]-'a'] 设为 false)。

6.2.3.将栈顶元素出栈。

6.2.4.更新栈的大小(即 size--)。

6.3.将 cur 入栈。

6.4.将 cur 标记为已入栈(即 enter[cur-'a'] 设为 true)。

6.5.将 cur 的出现次数减一。

7.根据栈中的元素构造移除重复字母后的结果字符串,并将其返回。

总的时间复杂度:O(n),其中 n 是字符串 s 的长度。

总的额外空间复杂度:O(1),因为使用了固定长度的数组和栈,与输入规模无关。

go完整代码如下:

package main

import "fmt"

func removeDuplicateLetters(s string) string {

	cnts := make([]int, 26)
enter := make([]bool, 26) for _, ch := range s {
cnts[ch-'a']++
} stack := make([]byte, 26)
size := 0 for i := 0; i < len(s); i++ {
cur := s[i]
if !enter[cur-'a'] {
for size > 0 && stack[size-1] > cur && cnts[stack[size-1]-'a'] > 0 {
enter[stack[size-1]-'a'] = false
size--
}
stack[size] = cur
size++
enter[cur-'a'] = true
}
cnts[cur-'a']--
} return string(stack[:size])
} func main() {
s := "cbacdcbc"
result := removeDuplicateLetters(s)
fmt.Println(result)
}

rust完整代码如下:

fn remove_duplicate_letters(s: String) -> String {
let mut cnts: [i32; 26] = [0; 26];
let mut enter: [bool; 26] = [false; 26];
let mut stack: Vec<u8> = Vec::new(); for ch in s.chars() {
cnts[(ch as u8 - b'a') as usize] += 1;
} for cur in s.bytes() {
let cur_index = (cur - b'a') as usize;
if !enter[cur_index] {
while let Some(&top) = stack.last() {
let top_index = (top - b'a') as usize;
if top > cur && cnts[top_index] > 0 {
enter[top_index] = false;
stack.pop();
} else {
break;
}
}
stack.push(cur);
enter[cur_index] = true;
}
cnts[cur_index] -= 1;
} String::from_utf8(stack).unwrap()
} fn main() {
let s = String::from("cbacdcbc");
let result = remove_duplicate_letters(s);
println!("{}", result);
}

c++完整代码如下:

#include <iostream>
#include <string>
#include <vector>
#include <cstring> std::string removeDuplicateLetters(std::string s) {
std::vector<int> cnts(26, 0);
std::vector<bool> enter(26, false);
std::vector<char> stack(26, '\\');
int size = 0; for (char ch : s) {
cnts[ch - 'a']++;
} for (char cur : s) {
int curIndex = cur - 'a';
if (!enter[curIndex]) {
while (size > 0&& stack[size - 1] > cur && cnts[stack[size - 1] - 'a'] > 0) {
enter[stack[size - 1] - 'a'] = false;
size--;
}
stack[size] = cur;
size++;
enter[curIndex] = true;
}
cnts[curIndex]--;
} return std::string(stack.begin(), stack.begin() + size);
} int main() {
std::string s = "cbacdcbc";
std::string result = removeDuplicateLetters(s);
std::cout << result << std::endl;
return 0;
}

c完整代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h> char* removeDuplicateLetters(char* s) {
int cnts[26] = {0};
int enter[26] = {0};
char stack[26];
int size = 0; for (int i = 0; s[i] != '\\'; i++) {
cnts[s[i] - 'a']++;
} for (int i = 0; s[i] != '\\'; i++) {
char cur = s[i];
if (!enter[cur - 'a']) {
while (size > 0&& stack[size - 1] > cur && cnts[stack[size - 1] - 'a'] > 0) {
enter[stack[size - 1] - 'a'] = 0;
size--;
}
stack[size] = cur;
size++;
enter[cur - 'a'] = 1;
}
cnts[cur - 'a']--;
} char* result = (char*)malloc(sizeof(char) * (size + 1));
memcpy(result, stack, size);
result[size] = '\\'; return result;
} int main() {
char* s = "cbacdcbc";
char* result = removeDuplicateLetters(s);
printf("%s\n", result);
free(result);
return 0;
}

2023-11-29:用go语言,给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。 需保证 返回结果的字典序最小。 要求不能打乱其他字符的相对位置)。 输入:s = “cba的更多相关文章

  1. 2015年4月27日---C语言:输出特殊图案,请在c环境中运行,看一看,Very Beautiful!

    ---恢复内容开始--- 题目:输出特殊图案,请在c环境中运行,看一看,Very Beautiful! 1.程序分析:字符共有256个.不同字符,图形不一样. 2.程序源代码: [code=c] #i ...

  2. 请求大神,C#如何截取字符串中指定字符之间的部分 按指定字符串分割 一分为二 c# 去除字符串中的某个已知字符

    string stra = "abcdefghijk";string strtempa = "c";string strtempb = "j" ...

  3. Go语言实现:【剑指offer】删除链表中重复的结点

    该题目来源于牛客网<剑指offer>专题. 给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中没有重复出现的数字. 示例 1: 输入: 1->2->3->3- ...

  4. BZOJ 1640 [Usaco2007 Nov]Best Cow Line 队列变换:贪心【字典序最小】

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1640 题意: 给你一个长度为n的字符串. 你可以将原串的首字母或尾字母移动到新串的末尾. ...

  5. 黑盒测试实践--Day5 11.29

    黑盒测试实践--Day5 11.29 今天完成任务情况: 分析系统需求,完成场景用例设计 小组负责测试的同学学习安装自动测试工具--QTP,并在线学习操作 小黄 今天的任务是完成场景测试用例的设计.在 ...

  6. C语言学习_一个简单程序的解释与C学习方法概括

    简单计算器程序示例: # include <stdio.h> //1.头文件 //2.加法函数 int add(int a,int b)//3.函数定义方式 { //4.函数体 retur ...

  7. CAD在网页中返回当前图纸的最小外包矩形框

    主要用到函数说明: _DMxDrawX::GetMcDbDatabaseBound 返回当前图纸的最小外包矩形框,详细说明如下: 参数 说明 DOUBLE* pLbx 返回最小外包矩形框左下角X值 D ...

  8. Catenyms (POJ2337) 字典序最小欧拉路

    // 很久不写图论,连模板也不熟悉了0.0 // 这题是一个技巧性比较高的暴力DFS Catenyms 题目大意 定义catenym为首尾字母相同的单词组成的单词对, 例如: dog.gopher g ...

  9. Go语言:编写一个 WebsiteRacer 的函数,用来对比请求两个 URL 来「比赛」,并返回先响应的 URL。如果两个 URL 在 10 秒内都未返回结果,返回一个 error。

    问题: 你被要求编写一个叫做 WebsiteRacer 的函数,用来对比请求两个 URL 来「比赛」,并返回先响应的 URL.如果两个 URL 在 10 秒内都未返回结果,那么应该返回一个 error ...

  10. [poj2337]求字典序最小欧拉回路

    注意:找出一条欧拉回路,与判定这个图能不能一笔联通...是不同的概念 c++奇怪的编译规则...生不如死啊... string怎么用啊...cincout来救? 可以直接.length()我也是长见识 ...

随机推荐

  1. 深入理解 python 虚拟机:生成器停止背后的魔法

    深入理解 python 虚拟机:生成器停止背后的魔法 在本篇文章当中主要给大家介绍 Python 当中生成器的实现原理,尤其是生成器是如何能够被停止执行,而且还能够被恢复的,这是一个非常让人疑惑的地方 ...

  2. PostgreSQL学习笔记-2.基础知识:INSERT、SELECT、运算符、表达式、约束

    PostgreSQL INSERT INTO 语句用于向表中插入新记录,兼容SQL通用语法. 语法 INSERT INTO 语句语法格式如下: INSERT INTO TABLE_NAME (colu ...

  3. 一些常见小程序的UI设计分享

    外卖优惠券小程序的UI设计 电子商城系统UI分享 A B C

  4. 合唱队形(lgP1091)

    思路: 先从左到右求一遍最长不下降子序列,再同样方法从右到左求一遍. 然后我们枚举分界点,则总人数就是左边一半加上右边一半的人数. 取最大值,输出答案. 见注释. #include<bits/s ...

  5. Python 利用pandas 和 matplotlib绘制柱状图

    当你需要展示数据时,图表是一个非常有用的工具.Python 中的 pandas 和 matplotlib 库提供了丰富的功能,可以帮助你轻松地绘制各种类型的图表.本文将介绍如何使用这两个库,绘制一个店 ...

  6. influxdb报错:cache-max-memory-size exceeded

    转载请注明出处: influxdb报错日志: 该错误信息表示 InfluxDB 引擎超过了缓存最大内存大小.这意味着 InfluxDB 的缓存使用量超出了配置的限制. 要解决此问题,可以采取以下步骤来 ...

  7. Java技术_基础技术(0003)_类执行顺序详解+实例(阿里面试题)+详细讲解+流程图

    类加载机制 加载.验证.准备.初始化和卸载这5个阶段的顺序是确定的,类的加载过程必须按照这种顺序按部就班地开始,而解析阶段则不一定:它在某些情况下可以在初始化阶段之后再开始,这是为了支持Java语言的 ...

  8. .net 温故知新【13】:Asp.Net Core WebAPI 使用依赖注入DI

    一.使用DI注入 在之前的文章中已经讲过DI的概念(.net 温故知新:[7]IOC控制反转,DI依赖注入),基于控制台程序演示了DI依赖注入的使用,基于Microsoft.Extensions.De ...

  9. Python利用pandas进行数据合并

    当使用Python中的pandas库时,merge函数是用于合并(或连接)两个数据框(DataFrame)的重要工具.它类似于SQL中的JOIN操作,允许你根据一个或多个键(key)将两个数据框连接起 ...

  10. C#12中的Primary Constructors(主构造函数)

    什么是主构造函数 把参数添加到class与record的类声明中就是主构造函数.例如 class Person(string name) { private string _name = name; ...