国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

華為OD機(jī)試之最長(zhǎng)連續(xù)子序列(Java源碼)

這篇具有很好參考價(jià)值的文章主要介紹了華為OD機(jī)試之最長(zhǎng)連續(xù)子序列(Java源碼)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

最長(zhǎng)連續(xù)子序列

題目描述

有N個(gè)正整數(shù)組成的一個(gè)序列。給定整數(shù)sum,求長(zhǎng)度最長(zhǎng)的連續(xù)子序列,使他們的和等于sum,返回此子序列的長(zhǎng)度,

如果沒(méi)有滿足要求的序列,返回-1。


輸入描述

第一行輸入是:N個(gè)正整數(shù)組成的一個(gè)序列

第二行輸入是:給定整數(shù)sum


輸出描述

最長(zhǎng)的連續(xù)子序列的長(zhǎng)度

備注

  • 輸入序列僅由數(shù)字和英文逗號(hào)構(gòu)成,數(shù)字之間采用英文逗號(hào)分隔
  • 序列長(zhǎng)度:1 <= N <= 200
  • 輸入序列不考慮異常情況

用例

輸入

1,2,3,4,2
6

輸出 3
說(shuō)明 1,2,3和4,2兩個(gè)序列均能滿足要求,所以最長(zhǎng)的連續(xù)序列為1,2,3,因此結(jié)果為3。
輸入 1,2,3,4,2
20
輸出 -1
說(shuō)明 沒(méi)有滿足要求的子序列,返回-1

題目解析

  1. 使用雙指針找到對(duì)相鄰的數(shù)進(jìn)行求和。若和正確,那么就判斷長(zhǎng)度是否比前面出現(xiàn)的長(zhǎng)度都大,若大就進(jìn)行記錄。
  2. 若和大于,那么就證明該區(qū)間內(nèi)不存在目標(biāo)序列。左指針右移,臨和減掉移出的左側(cè)的那個(gè)。
  3. 若和小于,就證明該區(qū)間還可以往右擴(kuò)充,右指針右移,臨和加上移入的那一個(gè)。這樣就避免了在內(nèi)部在使用循環(huán)計(jì)算區(qū)間和了。
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

public class T53 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		String input = sc.nextLine();
		int sum = Integer.parseInt(sc.nextLine());
		List<Integer> numList = new ArrayList<>();
		Arrays.stream(input.split(",")).forEach(s -> {
			numList.add(Integer.parseInt(s));
		});
		int left = 0;
		int right = 0;
		int tempSum = numList.get(left);// 臨時(shí)的區(qū)間和
		int len = -1;
		while (right < numList.size()) {
			if (tempSum < sum) {
				right++;
				if (right == numList.size())
					break;// 超出了
				tempSum += numList.get(right);
				// System.out.println(tempSum);
			} else if (tempSum > sum) {
				tempSum -= numList.get(left);
				left++;
			} else {
				// System.out.println(right - left + "-");
				// System.out.println(right + "-----" + left);
				if (len < right - left) {
					len = right - left + 1;
				}
				tempSum -= numList.get(left);
				left++;

			}
		}
		System.out.println(len);
	}
}


代碼運(yùn)行示意圖
華為OD機(jī)試之最長(zhǎng)連續(xù)子序列(Java源碼)
華為OD機(jī)試之最長(zhǎng)連續(xù)子序列(Java源碼)文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-485374.html

到了這里,關(guān)于華為OD機(jī)試之最長(zhǎng)連續(xù)子序列(Java源碼)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 華為OD機(jī)試之全量和已占用字符集(Java源碼)

    華為OD機(jī)試之全量和已占用字符集(Java源碼)

    題目描述 給定兩個(gè)字符集合,一個(gè)是全量字符集,一個(gè)是已占用字符集,已占用字符集中的字符不能再使用。 輸入描述 輸入一個(gè)字符串 一定包含@,@前為全量字符集 @后的為已占用字符集 已占用字符集中的字符一定是全量字符集中的字符 字符集中的字符跟字符之間使用英文

    2024年02月07日
    瀏覽(21)
  • 華為OD機(jī)試之阿里巴巴找黃金寶箱(II)(Java源碼)

    華為OD機(jī)試之阿里巴巴找黃金寶箱(II)(Java源碼)

    題目描述 一貧如洗的樵夫阿里巴巴在去砍柴的路上,無(wú)意中發(fā)現(xiàn)了強(qiáng)盜集團(tuán)的藏寶地,藏寶地有編號(hào)從0~n 的箱子,每個(gè)箱子上面貼有箱子中藏有金幣的數(shù)量。 從金幣數(shù)量中選出一個(gè)數(shù)字集合,并銷毀貼有這些數(shù)字的每個(gè)箱子,如果能銷毀一半及以上的箱子,則返回這個(gè)數(shù)字

    2024年02月09日
    瀏覽(21)
  • 華為OD機(jī)試之最小調(diào)整順序次數(shù)、特異性雙端隊(duì)列(Java源碼)

    題目描述 有一個(gè)特異性的雙端隊(duì)列,該隊(duì)列可以從頭部或尾部添加數(shù)據(jù),但是只能從頭部移出數(shù)據(jù)。 小A依次執(zhí)行2n個(gè)指令往隊(duì)列中添加數(shù)據(jù)和移出數(shù)據(jù)。其中n個(gè)指令是添加數(shù)據(jù)(可能從頭部添加、也可能從尾部添加),依次添加1到n;n個(gè)指令是移出數(shù)據(jù)。 現(xiàn)在要求移除數(shù)據(jù)

    2024年02月07日
    瀏覽(19)
  • 華為OD機(jī)試 - 最多等和不相交連續(xù)子序列(Java & JS & Python)

    題目描述 給定一個(gè)數(shù)組,我們稱其中連續(xù)的元素為連續(xù)子序列,稱這些元素的和為連續(xù)子序列的和。 數(shù)組中可能存在幾組連續(xù)子序列,組內(nèi)的連續(xù)子序列互不相交且有相同的和。 求一組連續(xù)子序列,組內(nèi)子序列的數(shù)目最多。 輸出這個(gè)數(shù)目。 輸入描述 第一行輸入為數(shù)組長(zhǎng)度

    2023年04月18日
    瀏覽(32)
  • 華為OD機(jī)試真題 Java 實(shí)現(xiàn)【在字符串中找出連續(xù)最長(zhǎng)的數(shù)字串】【2023 B卷 100分】,附詳細(xì)解題思路

    華為OD機(jī)試真題 Java 實(shí)現(xiàn)【在字符串中找出連續(xù)最長(zhǎng)的數(shù)字串】【2023 B卷 100分】,附詳細(xì)解題思路

    輸入一個(gè)字符串,返回其最長(zhǎng)的數(shù)字子串,以及其長(zhǎng)度。 若有多個(gè)最長(zhǎng)的數(shù)字子串,則將它們?nèi)枯敵觯ò丛址南鄬?duì)位置)。 本題含有多組樣例輸入。 數(shù)據(jù)范圍: 字符串長(zhǎng)度 1≤n≤200 , 保證每組輸入都至少含有一個(gè)數(shù)字。 輸入一個(gè)字符串。 輸出字符串中最長(zhǎng)的數(shù)

    2024年02月08日
    瀏覽(98)
  • 華為OD機(jī)試 - 最長(zhǎng)公共后綴(Java & JS & Python)

    題目描述 編寫一個(gè)函數(shù)來(lái)查找字符串?dāng)?shù)組中的最長(zhǎng)公共后綴; 如果不存在公共后綴,返回固定字符串: @Zero。 補(bǔ)充說(shuō)明: 字符串長(zhǎng)度范圍:[2, 1000] 字符串中字符取值范圍為[1, 126] 輸入描述 無(wú) 輸出描述 無(wú) 用例 輸入 [\\\"abc\\\",\\\"bbc\\\",\\\"c\\\"] 輸出 \\\"c\\\" 說(shuō)明 返回公共后綴: c 輸入 [\\\"aa\\\",\\\"b

    2024年02月13日
    瀏覽(25)
  • 華為OD機(jī)試之阿里巴巴找黃金寶箱(I)

    華為OD機(jī)試之阿里巴巴找黃金寶箱(I)

    題目描述 一貧如洗的樵夫阿里巴巴在去砍柴的路上,無(wú)意中發(fā)現(xiàn)了強(qiáng)盜集團(tuán)的藏寶地,藏寶地有編號(hào)從0~N的箱子,每個(gè)箱子上面貼有一個(gè)數(shù)字,箱子中可能有一個(gè)黃金寶箱。 黃金寶箱滿足排在它之前的所有箱子數(shù)字和等于排在它之后的所有箱子數(shù)字之和; 第一個(gè)箱子左邊部

    2024年02月09日
    瀏覽(19)
  • 華為OD機(jī)試 - 尋找符合要求的最長(zhǎng)子串(Java & JS & Python)

    題目描述 給定一個(gè)字符串s,找出這樣一個(gè)子串: 該子串中任意一個(gè)字符最多出現(xiàn)2次 該子串不包含指定某個(gè)字符 請(qǐng)你找出滿足該條件的最長(zhǎng)子串的長(zhǎng)度 輸入描述 第一行為:要求不包含的指定字符,為單個(gè)字符,取值范圍[0-9a-zA-Z] 第二行為:字符串s,每個(gè)字符范圍[0-9a-zA-

    2024年02月05日
    瀏覽(19)
  • 華為OD機(jī)試 - 最長(zhǎng)合法表達(dá)式(Java & JS & Python & C)

    華為OD機(jī)試 - 最長(zhǎng)合法表達(dá)式(Java & JS & Python & C)

    題目描述 提取字符串中的最長(zhǎng)合法簡(jiǎn)單數(shù)學(xué)表達(dá)式,字符串長(zhǎng)度最長(zhǎng)的,并計(jì)算表達(dá)式的值。如果沒(méi)有,則返回 0 。 簡(jiǎn)單數(shù)學(xué)表達(dá)式只能包含以下內(nèi)容: 0-9數(shù)字,符號(hào)+-* 說(shuō)明: 所有數(shù)字,計(jì)算結(jié)果都不超過(guò)long 如果有多個(gè)長(zhǎng)度一樣的,請(qǐng)返回第一個(gè)表達(dá)式的結(jié)果 數(shù)學(xué)表達(dá)

    2024年02月04日
    瀏覽(15)
  • 【華為OD統(tǒng)一考試B卷 | 200分】最長(zhǎng)的完全交替連續(xù)方波信號(hào)(C++ Java JavaScript python)

    在線OJ 已購(gòu)買本專欄用戶,請(qǐng)私信博主開(kāi)通賬號(hào),在線刷題?。?! 運(yùn)行出現(xiàn) Runtime Error 0Aborted,請(qǐng)忽略 華為OD統(tǒng)一考試A卷+B卷 新題庫(kù)說(shuō)明 2023年5月份,華為官方已經(jīng)將的 2022/0223Q(1/2/3/4)統(tǒng)一修改為OD統(tǒng)一考試(A卷)和OD統(tǒng)一考試(B卷)。 你收到的鏈接上面會(huì)標(biāo)注A卷還是B卷。

    2024年02月11日
    瀏覽(29)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包