選擇、冒泡排序,二分查找法以及一些for迴圈的靈活運用

来源:http://www.cnblogs.com/tawny-tw/archive/2017/06/23/7059046.html
-Advertisement-
Play Games

import java.util.Arrays;//冒泡排序 public class Test { public static void main(String[] args) { int[] array = { 31, 22, 15, 77, 52, 32, 18, 25, 16, 7 }; /... ...


import java.util.Arrays;
//冒泡排序
public class Test { public static void main(String[] args) { int[] array = { 31, 22, 15, 77, 52, 32, 18, 25, 16, 7 }; // 冒泡 --> 兩兩比較 --> 提取出最大的數 在最後一位
    //拿第一位和它後面的一位進行 兩兩比較
System.out.println(Arrays.toString(array)); for (int j = 0; j < array.length; j++) { for (int i = 0; i < array.length - 1 - j; i++) { // 如果前面的數大於後面的數 交換位置 if (array[i] < array[i + 1]) { int temp = array[i]; array[i] = array[i + 1]; array[i + 1] = temp; } } } System.out.println(Arrays.toString(array)); } }
import java.util.Arrays;
//選擇排序
public class Test {

    public static void main(String[] args) {
        int[] array = { 31, 22, 15, 77, 52, 32, 18, 25, 16, 7 };
        // 選擇 --> 第一位與後面所有的數字進行比較 
        System.out.println(Arrays.toString(array));
        for (int i = 0; i < array.length; i++) {
            for (int j = i + 1; j < array.length; j++) {
                if (array[i] < array[j]) {
                    // 如果 array[0]比array[1]大,交換位置
                    // 第三方變數temp
                    int temp = array[i];
                    array[i] = array[j];
                    array[j] = temp;
                }
            }
        }
        System.out.println(Arrays.toString(array));
    }
}

 

import java.util.Arrays;
import java.util.Scanner;

//  二分查找  折半查找法    從中間斬斷,比較值。繼續比較
public class Test11 {

    public static void main(String[] args) {
        // 二分查找法 插入排序
        int[] array = { 3, 10, 15, 22, 33, 51, 77, 88 };
        System.out.println(Arrays.toString(array));
        Scanner input = new Scanner(System.in);
        do {

            System.out.print("輸入需要插入的數據:");
            int number = input.nextInt();
       // 每次獲取最左邊的數和最右邊的數 int left = 0; int right = array.length - 1; int result = recursion(array, left, right, number); System.out.println(result); int[] newArray = new int[array.length + 1]; for (int i = 0; i < newArray.length; i++) { if (i < result) { newArray[i] = array[i]; } else if (i == result) { newArray[i] = number; } else { newArray[i] = array[i - 1]; } } array = newArray; System.out.println(Arrays.toString(array)); } while (true); } //遞歸 public static int recursion(int[] array, int left, int right, int number) { // 如果大於右邊,或者小於左邊 if (array[0] > number) return 0; else if (array[array.length - 1] < number) return array.length;        int center = (left + right) / 2; if (left == right - 1) return right; if (array[center] > number) { return recursion(array, left, center, number); } else { return recursion(array, center, right, number); } } }
//for迴圈列印矩形
public class Rect {

    public void show(int width, int height) {

        for (int i = 0; i < width; i++) {
            for (int j = 0; j < height; j++) {
                if (i == 0 || j == 0 || i == width - 1 || j == height - 1)
                    System.out.print("*");
                else
                    System.out.print(" ");
            }
            System.out.println();
        }
    }
}
//for迴圈列印菱形
public class Rhombus {

    public void show(int height) {
        int half = height / 2;
        for (int i = 1; i <= half; i++) {
            // 先打空格
            for (int j = half - i + 1; j > 0; j--) {
                System.out.print(" ");
            }
            for (int j = 0; j < 2 * i - 1; j++) {
                System.out.print("*");
            }
            System.out.println();
        }

        for (int i = 0; i < 2 * half + 1; i++) {
            System.out.print("*");
        }
        System.out.println();

        for (int i = 1; i <= half; i++) {
            // 先打空格
            for (int j = i; j > 0; j--) {
                System.out.print(" ");
            }
            for (int j = 0; j < 2 * (half - i) + 1; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
    }

}
//for迴圈列印等腰三角形
public class Isosceles {

    public void show(int height) {
        for (int i = 1; i <= height; i++) {
            // 先打空格
            for (int j = height - i; j > 0; j--) {
                System.out.print(" ");
            }
            for (int j = 0; j < 2 * i - 1; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
    }
}
//for迴圈列印之間三角形
public class Triangle {

    public void show(String str, int height) {
        for (int i = 0; i < height; i++) {
            for (int j = 0; j < i + 1; j++) {
                System.out.print(str);
            }
            System.out.println();
        }
    }

}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • jvm虛擬機在運行時需要用到的記憶體區域.廣泛一點就是堆和棧,其實不然,堆和棧只是相對比較籠統的說法,真正區分有如下幾個 先上圖一: 總的就是 java的記憶體模型 記憶體模型又分堆記憶體(heap)和方法區(有時也稱為non-heap)和棧 堆又分新生代(Young)和老年代(old/Tenured) 新 ...
  • 進位轉換的符號表為[0-9a-zA-Z],共61個字元,最大可表示62進位。 思路是原進位先轉換為10進位,再轉換到目標進位。 疑問: 對於負數,有小伙伴說可以直接將符號丟棄,按照整數進行進位轉換,最後再將負號補回來,我認為這種做法是不對的。 正確的做法是:考慮好按照16位(short)還是32位( ...
  • Python 是強類型的動態腳本語言 。強類型:不允許不同類型相加動態:不使用顯示數據類型聲明,且確定一個變數的類型是在第一次給它賦值的時候腳本語言:一般也是解釋型語言,運行代碼只需要一個解釋器,不需要編譯強類型語言和弱類型語言1.強類型語言:使之強制數據類型定義的語言。沒有強制類型轉化前,不允許兩... ...
  • 題目描述 已知有兩個字串 A, B 及一組字串變換的規則(至多6個規則): A1 -> B1 A2 -> B2 規則的含義為:在 A$中的子串 A1 可以變換為 B1、A2 可以變換為 B2 …。 例如:A='abcd'B='xyz' 變換規則為: ‘abc’->‘xu’‘ud’->‘y’‘y’-> ...
  • 數據類型 關鍵字 位元組數 數值型 整數型 byte 1 short 2 int 4 long 8 浮點型 float 4 double 8 布爾型 boolean 1(位) 字元型 char 2 ...
  • 今天在調試項目的時候出現下麵的錯誤信息: SoapFault looks like we got no XML document (D:\phpStudy\WWW\self.shop.xunmall.com\components\Proxy.php:477) #0 D:\phpStudy\WWW\s ...
  • Java2 平臺包括標準版(J2SE),企業版(J2EE)和為微縮版(J2ME)三個版本: Standard Edition(標準版)J2SE 包括那些構成Java語言核心的類。 例如:資料庫鏈接,介面定義,輸入/輸出,網路編程 Enterprise Edition(企業版)J2EE 包含J2SE中 ...
  • 題目背景 高手最近談戀愛了。不過是單相思。“即使是單相思,也是完整的愛情”,高手從未放棄對它的追求。今天,這個陽光明媚的早晨,太陽從西邊緩緩升起。於是它找到高手,希望在晨讀開始之前和高手一起在鰲頭山上一起散步。高手當然不會放棄這次夢寐以求的機會,他已經準備好了一切。 題目描述 鰲頭山上有n個觀景點, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...