java查找字符串,java查找字符串中字符出現的次數

本文目錄一覽:

java中怎麼判斷一個字符串中包含某個字符或字符串

Java中字符串中子串的查找共有四種方法,如下:

1、int indexOf(String str) :返回第一次出現的指定子字符串在此字符串中的索引。

2、int indexOf(String str, int startIndex):從指定的索引處開始,返回第一次出現的指定子字符串在此字符串中的索引。

3、int lastIndexOf(String str) :返回在此字符串中最右邊出現的指定子字符串的索引。

4、int lastIndexOf(String str, int startIndex) :從指定的索引處開始向後搜索,返回在此字符串中最後一次出現的指定子字符串的索引。

示例

下面的示例說明了 indexOf 方法的用法。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

function IndexDemo(str2){

var str1 = “BABEBIBOBUBABEBIBOBU”

var s = str1.indexOf(str2);

return(s);

}

public class FirstDemo {

/**

*API中String的常用方法

*/

// 查找指定字符串是否存在

public static void main(String[] args) {

String str1 = “abcdefghijklmnabc”;

// 從頭開始查找是否存在指定的字符

System.out.println(str1.indexOf(“c”));

// 從第四個字符位置開始往後繼續查找

System.out.println(str1.indexOf(“c”, 3));

//若指定字符串中沒有該字符則系統返回-1

System.out.println(str1.indexOf(“x”));

}

JAVA中怎樣在一個字符串中查找給定的子字符串

調用類java.lang.String

的以下方法都可以:

public int indexOf(String str)

返回指定子字符串在此字符串中第一次出現處的索引。

參數:

str – 任意字符串。

返回:

如果字符串參數作為一個子字符串在此對象中出現,則返回第一個這種子字符串的第一個字符的索引;如果它不作為一個子字符串出現,則返回 -1。

public int indexOf(String str,int fromIndex)

返回指定子字符串在此字符串中第一次出現處的索引,從指定的索引開始。

參數:

str – 要搜索的子字符串。

fromIndex – 開始搜索的索引位置。

返回:

指定子字符串在此字符串中第一次出現處的索引,從指定的索引開始。

public int lastIndexOf(String str)

返回指定子字符串在此字符串中最右邊出現處的索引。將最右邊的空字符串 “” 視為出現在索引值 this.length() 處。

參數:

str – 要搜索的子字符串。

返回:

如果字符串參數作為一個子字符串在此對象中出現一次或多次,則返回最後一個這種子字符串的第一個字符。如果它不作為一個子字符串出現,則返回 -1。

public int lastIndexOf(String str,int fromIndex)

返回指定子字符串在此字符串中最後一次出現處的索引,從指定的索引開始反向搜索。

參數:

str – 要搜索的子字符串。

fromIndex – 開始搜索的索引位置。

返回:

指定子字符串在此字符串中最後一次出現處的索引。

怎麼樣利用二分法查找數據中的字串JAVA

二分查找也稱折半查找(Binary Search),它是一種效率較高的查找方法。但是,折半查找要求線性表必須採用順序存儲結構,而且表中元素按關鍵字有序排列。

二分查找優缺點

優點是比較次數少,查找速度快,平均性能好;

其缺點是要求待查表為有序表,且插入刪除困難。

因此,折半查找方法適用於不經常變動而查找頻繁的有序列表。

使用條件:查找序列是順序結構,有序。

過程

首先,假設表中元素是按升序排列,將表中間位置記錄的關鍵字與查找關鍵字比較,如果兩者相等,則查找成功;否則利用中間位置記錄將表分成前、後兩個子表,如果中間位置記錄的關鍵字大於查找關鍵字,則進一步查找前一子表,否則進一步查找後一子表。重複以上過程,直到找到滿足條件的記錄,使查找成功,或直到子表不存在為止,此時查找不成功。

利用循環的方式實現二分法查找

public class BinarySearch {

public static void main(String[] args) {

// 生成一個隨機數組        int[] array = suiji();

// 對隨機數組排序        Arrays.sort(array);

System.out.println(“產生的隨機數組為: ” + Arrays.toString(array));

System.out.println(“要進行查找的值: “);

Scanner input = new Scanner(System.in);

// 進行查找的目標值        int aim = input.nextInt();

// 使用二分法查找        int index = binarySearch(array, aim);

System.out.println(“查找的值的索引位置: ” + index);

}

/**     * 生成一個隨機數組     *

* @return 返回值,返回一個隨機數組     */

private static int[] suiji() {

// random.nextInt(n)+m  返回m到m+n-1之間的隨機數        int n = new Random().nextInt(6) + 5;

int[] array = new int[n];

// 循環遍歷為數組賦值        for (int i = 0; i array.length; i++) {

array[i] = new Random().nextInt(100);

}

return array;

}

/**     * 二分法查找  —循環的方式實現     *

* @param array 要查找的數組     * @param aim 要查找的值     * @return 返回值,成功返回索引,失敗返回-1     */

private static int binarySearch(int[] array, int aim) {

// 數組最小索引值        int left = 0;

// 數組最大索引值        int right = array.length – 1;

int mid;

while (left = right) {

mid = (left + right) / 2;

// 若查找數值比中間值小,則以整個查找範圍的前半部分作為新的查找範圍            if (aim array[mid]) {

right = mid – 1;

// 若查找數值比中間值大,則以整個查找範圍的後半部分作為新的查找範圍            } else if (aim array[mid]) {

left = mid + 1;

// 若查找數據與中間元素值正好相等,則放回中間元素值的索引      } else {

return mid;

}

}

return -1;

}}

運行結果演示:

由以上運行結果我們得知,如果要查找的數據在數組中存在,則輸出該數據在數組中的索引;如果不存在則輸出 -1 ,也就是打印 -1 則該數在數組中不存在,反之則存在。

四、利用遞歸的方式實現二分法查找

public class BinarySearch2 {

public static void main(String[] args) {

// 生成一個隨機數組        int[] array = suiji();

// 對隨機數組排序        Arrays.sort(array);

System.out.println(“產生的隨機數組為: ” + Arrays.toString(array));

System.out.println(“要進行查找的值: “);

Scanner input = new Scanner(System.in);

// 進行查找的目標值        int aim = input.nextInt();

// 使用二分法查找        int index = binarySearch(array, aim, 0, array.length – 1);

System.out.println(“查找的值的索引位置: ” + index);

}

/**     * 生成一個隨機數組     *     * @return 返回值,返回一個隨機數組     */

private static int[] suiji() {

// Random.nextInt(n)+m  返回m到m+n-1之間的隨機數        int n = new Random().nextInt(6) + 5;

int[] array = new int[n];

// 循環遍歷為數組賦值        for (int i = 0; i array.length; i++) {

array[i] = new Random().nextInt(100);

}

return array;

}

/**     * 二分法查找 —遞歸的方式     *     * @param array 要查找的數組     * @param aim   要查找的值     * @param left  左邊最小值     * @param right 右邊最大值     * @return 返回值,成功返回索引,失敗返回-1     */

private static int binarySearch(int[] array, int aim, int left, int right) {

if (aim array[left] || aim array[right]) {

return -1;

}

// 找中間值        int mid = (left + right) / 2;

if (array[mid] == aim) {

return mid;

} else if (array[mid] aim) {

//如果中間值大於要找的值則從左邊一半繼續遞歸            return binarySearch(array, aim, left, mid – 1);

} else {

//如果中間值小於要找的值則從右邊一半繼續遞歸            return binarySearch(array, aim, mid + 1, array.length-1);

}

}}

運行結果演示:

總結:

遞歸相較於循環,代碼比較簡潔,但是時間和空間消耗比較大,效率低。在實際的學習與工作中,根據情況選擇使用。通常我們如果使用循環實現代碼只要不是太繁瑣都選擇循環的方式實現~

java怎麼查找字符串中是否包含某個字段

方法:

1、描述:java.lang.String.contains() 方法返回true,當且僅當此字符串包含指定的char值序列

2、聲明:如下圖

3、返回值:此方法返回true,如果此字符串包含,否則返回false。

4、實例:如下圖

Java 基礎語法

一個Java程序可以認為是一系列對象的集合,而這些對象通過調用彼此的方法來協同工作。下面簡要介紹下類、對象、方法和實例變量的概念。

對象:對象是類的一個實例,有狀態和行為。例如,一條狗是一個對象,它的狀態有:顏色、名字、品種;行為有:搖尾巴、叫、吃等。

類:類是一個模板,它描述一類對象的行為和狀態。

方法:方法就是行為,一個類可以有很多方法。邏輯運算、數據修改以及所有動作都是在方法中完成的。

實例變量:每個對象都有獨特的實例變量,對象的狀態由這些實例變量的值決定。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/185941.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-26 21:08
下一篇 2024-11-26 21:08

相關推薦

  • 英語年齡用連字符號(Hyphenation for English Age)

    英語年齡通常使用連字符號表示,比如 “five-year-old boy”。本文將從多個方面探討英語年齡的連字符使用問題。 一、英語年齡的表達方式 英語中表…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Python字符串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字符串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字符串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Python字符轉列表指南

    Python是一個極為流行的腳本語言,在數據處理、數據分析、人工智能等領域廣泛應用。在很多場景下需要將字符串轉換為列表,以便於操作和處理,本篇文章將從多個方面對Python字符轉列…

    編程 2025-04-29
  • Python中將字符串轉化為浮點數

    本文將介紹在Python中將字符串轉化為浮點數的常用方法。在介紹方法之前,我們先來思考一下這個問題應該如何解決。 一、eval函數 在Python中,最簡單、最常用的將字符串轉化為…

    編程 2025-04-29
  • Python如何減少相同請求次數

    Python作為一種靈活的語言,經常用於處理網絡請求。但相同的請求被重複發出會導致一些問題,因此本文將介紹如何使用Python減少相同請求次數。 一、使用緩存 在應用程序中使用緩存…

    編程 2025-04-29

發表回復

登錄後才能評論