用八種編程語(yǔ)言來(lái)找出最長(zhǎng)的字符串

用八種編程語(yǔ)言來(lái)找出最長(zhǎng)的字符串

我試圖使用最快的算法來(lái)在每種語(yǔ)言中完成任務(wù)要求,如果你找到了更好的方案眨攘,請(qǐng)告訴我一下。

給定一個(gè)字符串str嚣州,找到不重復(fù)字符的最長(zhǎng)子字符串鲫售。

比如我們有 “ABDEFGABEF”, 最長(zhǎng)的字符串是 “BDEFGA” 和 “DEFGAB”, 長(zhǎng)度為6.

再如 “BBBB” 最長(zhǎng)字符串是 “B”, 長(zhǎng)度為1.

再比如 “neatcoding” 最長(zhǎng)字符串是“neatcodi”, 長(zhǎng)度為8.

所需的時(shí)間復(fù)雜度為O(n),其中n是字符串的長(zhǎng)度该肴。

我們將逐個(gè)字符地遍歷該字符串

檢查此字符是否在當(dāng)前子字符串中情竹,如果是,則將當(dāng)前子字符串保存到子字符串集合中匀哄,使用此字符作為起始值創(chuàng)建一個(gè)新的子字符串秦效;

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 如果否,則將此字符添加到當(dāng)前子字符串中涎嚼;

至此,循環(huán)結(jié)束,檢查當(dāng)前子字符串是否為空阱冶,如果是若皱,則不執(zhí)行任何操作

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 如果否,請(qǐng)將其添加到子字符串集合

我們?cè)O(shè)置一個(gè)對(duì)象來(lái)存儲(chǔ)最長(zhǎng)的子字符串,

現(xiàn)在像樊,讓我們遍歷子字符串集合涂滴,找到最長(zhǎng)的一個(gè)

? ? 檢查當(dāng)前子字符串是否更長(zhǎng)首量,如果是觉啊,則替換最長(zhǎng)的字符串

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 如果沒(méi)有,什么也不做

最后,我們有最長(zhǎng)的子字符串。

讓我們編碼。

In Javascript:

returnLongestNonRepeatSubString = (s) => {

? ? if(!s){

? ? ? return "";

? ? }

? ? let subCollection = [];

? ? let currentSub = "";

? ? let currentSet = new Set;

? ? for(let i = 0; i < s.length; i ++) {

? ? ? let c = s[i];

? ? ? if(!currentSet.has(c)) {

? ? ? ? currentSub +=c;

? ? ? ? currentSet.add(c);

? ? ? }

? ? ? else {

? ? ? ? subCollection.push(currentSub);

? ? ? ? currentSub = [];

? ? ? ? currentSet.clear();

? ? ? ? currentSub = "" + c;

? ? ? ? currentSet.add(c);

? ? ? }

? ? }

? ? if(currentSub.length > 0){

? ? ? subCollection.push(currentSub);

? ? }

? ? let longest = "";

? ? for(let i = 0 ; i < subCollection.length ; i ++) {

? ? ? let sub = subCollection[i];

? ? ? if(sub.length > longest.length)? {

? ? ? ? longest = sub;

? ? ? }

? ? }

? ? return longest;

? }


console.log(returnLongestNonRepeatSubString("ABDEFGABEF"))

console.log(returnLongestNonRepeatSubString("BBBB"))

console.log(returnLongestNonRepeatSubString("neatcoding"))

In C#:


using System;

using System.Text;

using System.Collections.Generic;

public class NeatCoding

{

public static void Main(string[] args)

{

//Your code goes here

Console.WriteLine(returnLongestNonRepeatSubString("ABDEFGABEF"));

Console.WriteLine(returnLongestNonRepeatSubString("BBBB"));

Console.WriteLine(returnLongestNonRepeatSubString("neatcoding"));

}

static string returnLongestNonRepeatSubString(string s)

{

if (string.IsNullOrEmpty(s))

{

return "";

}

List<string> subCollection = new List<string>();

StringBuilder currentSub = new StringBuilder();

HashSet<char> hashChar = new HashSet<char>();

for (int i = 0; i < s.Length; i++)

{

char c = s[i];

if (!hashChar.Contains(c))

{

hashChar.Add(c);

currentSub.Append(c);

}

else

{

subCollection.Add(currentSub.ToString());

hashChar.Clear();

currentSub.Clear();

currentSub.Append(c);

hashChar.Add(c);

}

}

if (currentSub.Length > 0)

{

subCollection.Add(currentSub.ToString());

}

string longest = "";

for (int i = 0; i < subCollection.Count; i++)

{

string sub = subCollection[i];

if (sub.Length > longest.Length)

{

longest = sub;

}

}

return longest;

}

}

In Java:

import java.util.*;

public class NeatCoding{

? ? public static void main(String []args){

? ? ? ? System.out.println(returnLongestNonRepeatSubString("ABDEFGABEF"));

? ? ? ? System.out.println(returnLongestNonRepeatSubString("BBBB"));

? ? ? ? System.out.println(returnLongestNonRepeatSubString("neatcoding"));

? ? }


? ? static String returnLongestNonRepeatSubString(String s)

? ? {

? ? ? if (s == null || s.length() == 0)

? ? ? {

? ? ? ? ? return "";

? ? ? }


? ? ? List<String> subCollection = new ArrayList<String>();

? ? ? HashSet<Character> set=new HashSet();?

? ? ? StringBuilder currentSub = new StringBuilder();

? ? ? for (int i = 0; i < s.length(); i++)

? ? ? {

? ? ? ? ? char c = s.charAt(i);

? ? ? ? ? if (!set.contains(c))

? ? ? ? ? {

? ? ? ? ? ? ? currentSub.append(c);

? ? ? ? ? }

? ? ? ? ? else

? ? ? ? ? {

? ? ? ? ? ? ? set.add(c);

? ? ? ? ? ? ? subCollection.add(currentSub.toString());

? ? ? ? ? ? ? currentSub.setLength(0);

? ? ? ? ? ? ? currentSub.append(c);

? ? ? ? ? }

? ? ? }


? ? ? if (currentSub.length() > 0)

? ? ? {

? ? ? ? ? subCollection.add(currentSub.toString());

? ? ? }


? ? ? String longest = "";

? ? ? for (int i = 0; i < subCollection.size(); i++)

? ? ? {

? ? ? ? ? String sub = subCollection.get(i);

? ? ? ? ? if (sub.length() > longest.length())

? ? ? ? ? {

? ? ? ? ? ? ? longest = sub;

? ? ? ? ? }

? ? ? }


? ? ? return longest;

? ? }

}

In Kotlin:

fun main() {

? ? println(returnLongestNonRepeatSubString("ABDEFGABEF"))

? ? println(returnLongestNonRepeatSubString("BBBB"))

? ? println(returnLongestNonRepeatSubString("neatcoding"))

}

fun returnLongestNonRepeatSubString(s: String?): String {

? if (s == null || s.length == 0) {

? ? ? return ""

? }

? val subCollection = ArrayList<String>()

? var currentSub = ""

? var currentSet: HashSet<Char> = HashSet()?

? for (i in 0 until s.length) {

? ? ? val c = s[i]

? ? ? if (!currentSet.contains(c)) {

? ? ? ? ? currentSub += c

? ? ? ? ? currentSet.add(c)

? ? ? } else {

? ? ? ? ? subCollection.add(currentSub)

? ? ? ? ? currentSub = "" + c

? ? ? ? ? currentSet.clear()

? ? ? ? ? currentSet.add(c)

? ? ? }

? }

? if (currentSub.length > 0) {

? ? ? subCollection.add(currentSub)

? }

? var longest = ""

? for (i in subCollection.indices) {

? ? ? val sub = subCollection[i]

? ? ? if (sub.length > longest.length) {

? ? ? ? ? longest = sub

? ? ? }

? }

? return longest

}

In Golang:

package main

import (

"fmt"

"bytes"

)

func main() {

fmt.Println(returnLongestNonRepeatSubString("ABDEFGABEF"))

fmt.Println(returnLongestNonRepeatSubString("BBBB"))

fmt.Println(returnLongestNonRepeatSubString("neatcoding"))

}

func returnLongestNonRepeatSubString(s string) string {

? if len(s) == 0 {

? ? return ""

? }

? var subCollection []string

? var currentSub bytes.Buffer

? currentMap := map[byte]bool{}

? for i := 0; i < len(s); i++ {

? ? var c = s[i]

? ? _, ok := currentMap[c]

? ? if !ok {

? ? ? ? currentSub.WriteByte(c)

currentMap[c] = true

? ? } else {

? ? ? ? subCollection = append(subCollection, currentSub.String())

? ? ? ? currentSub .Reset()

? ? ? ? currentSub.WriteByte(c)

? ? ? ? currentMap = map[byte]bool{}

currentMap[c] = true

? ? }

? }

? if currentSub.Len() > 0 {

? ? subCollection = append(subCollection, currentSub.String())

? }

? var longest = ""

? for _, sub := range subCollection {

? ? if? len(sub) > len(longest) {

? ? ? ? longest = sub

? ? }

? }

? return longest

}

In c++:

#include <iostream>

#include <vector>

#include <set>

#include <sstream>

using namespace std;

string

returnLongestNonRepeatSubString (const string & s)

{

? ? if (s.empty ())

? ? {

? ? ? ? return "";

? ? }

? ? std::vector <string> subCollection;

? ? stringstream currentSub;

? ? set <char> currentSet;

? ? for (int i = 0; i < s.length (); i++)

? ? {

? ? ? ? char c = s[i];

? ? ? ? if (currentSet.find (c) == currentSet.end())

? ? ? ? {

? ? ? ? ? ? currentSub << c;

? ? ? ? ? ? currentSet.insert(c);

? ? ? ? }

? ? ? ? else

? ? ? ? {

? ? ? ? ? ? subCollection.push_back (currentSub.str());

? ? ? ? ? ? currentSub.clear();

? ? ? ? ? ? currentSub << c;


? ? ? ? ? ? currentSet.clear();

? ? ? ? ? ? currentSet.insert(c);

? ? ? ? }

? ? }

? ? if( currentSub.gcount() > 0)

? ? {

? ? ? ? subCollection.push_back (currentSub.str());

? ? }

? ? string longest = "";

? ? for (int i = 0; i < subCollection.size(); i++)

? ? {

? ? ? ? string sub = subCollection.at(i);

? ? ? ? if (sub.length() > longest.length())

? ? ? ? {

? ? ? ? ? ? longest = sub;

? ? ? ? }

? ? }

? ? return longest;

}

int main()

{

? ? cout<<returnLongestNonRepeatSubString("ABDEFGABEF")<<std::endl;

? ? cout<<returnLongestNonRepeatSubString("BBBB")<<std::endl;

? ? cout<<returnLongestNonRepeatSubString("neatcoding")<<std::endl;

? ? return 0;

}

In Python:

def returnLongestNonRepeatSubString(s):

? ? if not s:

? ? ? ? return ""

? ? subCollection = []

? ? currentSub = []

? ? currentSet = set()

? ? for c in s:

? ? ? ? if (c not in currentSet):

? ? ? ? ? ? currentSet.add(c)

? ? ? ? ? ? currentSub.append(c)

? ? ? ? else:

? ? ? ? ? ? subCollection.append(''.join(currentSub))

? ? ? ? ? ? currentSub = [c]

? ? ? ? ? ? currentSet.clear()

? ? ? ? ? ? currentSet.add(c)


? ? if len(currentSub) > 0:

? ? ? ? subCollection.append(''.join(currentSub))


? ? longest = ""

? ? for sub in subCollection:

? ? ? ? if (len(sub) > len(longest)):

? ? ? ? ? ? longest = sub


? ? return longest

print(returnLongestNonRepeatSubString("ABDEFGABEF"))

print(returnLongestNonRepeatSubString("BBBB"))

print(returnLongestNonRepeatSubString("neatcoding"))

In Swift:

import Foundation

func returnLongestNonRepeatSubString (s: String) -> String {

? if (s == nil || s.isEmpty) {

? ? ? ? ? return ""

? }

? var subCollection =? [String]()

? var currentSub = ""

? var currentSet = Set<Character>()

? for c in s {

? ? ? currentSet.contains(c)

? ? ? if !currentSet.contains(c)? {

? ? ? ? ? currentSet.insert(c)

? ? ? ? ? currentSub.append(c)

? ? ? }

? ? ? else {

? ? ? ? ? subCollection.append(currentSub);

? ? ? ? ? currentSet = []

? ? ? ? ? currentSub = String(c)

? ? ? ? ? currentSet.insert(c)

? ? ? }

? }

? if currentSub.count > 0 {

? ? ? ? subCollection.append(currentSub);

? }

? var longest = ""

? for sub in subCollection {

? ? ? ? if sub.length > longest.length {

? ? ? ? ? ? longest = sub

? ? ? ? }

? }

? return longest

}

print(returnLongestNonRepeatSubString(s: "ABDEFGABEF"))

print(returnLongestNonRepeatSubString(s: "BBBB"))

print(returnLongestNonRepeatSubString(s: "neatcoding"))

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末嘲更,一起剝皮案震驚了整個(gè)濱河市李破,隨后出現(xiàn)的幾起案子诽俯,更是在濱河造成了極大的恐慌颜启,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,324評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件济炎,死亡現(xiàn)場(chǎng)離奇詭異耐床,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)偎箫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人断序,你說(shuō)我怎么就攤上這事茸炒。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,328評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)倚聚。 經(jīng)常有香客問(wèn)我白热,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,147評(píng)論 1 292
  • 正文 為了忘掉前任粘招,我火速辦了婚禮磷醋,結(jié)果婚禮上瑰抵,老公的妹妹穿的比我還像新娘逛球。我一直安慰自己,他們只是感情好氯葬,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著孩锡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪亥贸。 梳的紋絲不亂的頭發(fā)上讹俊,一...
    開(kāi)封第一講書(shū)人閱讀 51,115評(píng)論 1 296
  • 那天贩疙,我揣著相機(jī)與錄音,去河邊找鬼。 笑死仪壮,一個(gè)胖子當(dāng)著我的面吹牛匙瘪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播坐搔,決...
    沈念sama閱讀 40,025評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼藏研,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了概行?” 一聲冷哼從身側(cè)響起蠢挡,我...
    開(kāi)封第一講書(shū)人閱讀 38,867評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后业踏,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體禽炬,經(jīng)...
    沈念sama閱讀 45,307評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評(píng)論 2 332
  • 正文 我和宋清朗相戀三年勤家,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了腹尖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,688評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伐脖,死狀恐怖热幔,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情晓殊,我是刑警寧澤断凶,帶...
    沈念sama閱讀 35,409評(píng)論 5 343
  • 正文 年R本政府宣布伤提,位于F島的核電站巫俺,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏肿男。R本人自食惡果不足惜介汹,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望舶沛。 院中可真熱鬧嘹承,春花似錦、人聲如沸如庭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,657評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)坪它。三九已至骤竹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間往毡,已是汗流浹背蒙揣。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,811評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留开瞭,地道東北人懒震。 一個(gè)月前我還...
    沈念sama閱讀 47,685評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像嗤详,于是被迫代替她去往敵國(guó)和親个扰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容