牛客網BC115---超級聖誕樹(java)

来源:https://www.cnblogs.com/skypeng/archive/2023/04/15/17320362.html
-Advertisement-
Play Games

和女朋友坐一塊的時候,突然想到了,哈哈哈哈哈 不會很難!!! import java.util.*; import java.lang.Math; // 註意類名必須為 Main, 不要有任何 package xxx 信息 public class Main { public static void ...


和女朋友坐一塊的時候,突然想到了,哈哈哈哈哈

不會很難!!!

 

import java.util.*;

import java.lang.Math;

// 註意類名必須為 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);

        /**
		思考過程如下:
        小三角形個數為 3^(n-1)
        1 3 9 27
        3^(1-1) = 1
        3^(2-1) = 3
        3^(3-1) = 9
        3^(4-1) = 27
        3^(5-1) = 81

        // 去除桿子有多少層					用到了
        n
        3x1    3       3*2^(1-1)
        3x2    6       3*2^(2-1)
        3x4    12
        3x8    24
        3x16   48
        int allP = 3 * (int)Math.pow(2, n - 1);
        

        最底層三角形個數                	沒用到
        n
        1   1   0+1             2^(n-1)
        2   2   1+1             
        3   4   2+1+1
        4   8   4+2+1+1
        5   16  8+4+2+1+1
        6   32  16+8+4+2+1+1
        int lastPT = Math.pow(2, n - 1)

        最底層寬度  最底層三角形個數*6   	用到了
        n
        1 6   
        2 12  
        3 24
        4 48
        5 96
        int lastPW = (int)Math.pow(2, n - 1) * 6;
        24 - 3 - 12 - 0


        左邊寬 最底層寬度 - 6 / 2  每三行-3   用到了
        1 0
        2 3-0
        3 9-6-3-0
        4 21-18-15-12-9-6-3-0
        int leftW = (lastPW - 6) / 2;


        最底層判斷          需要
        int nowP = 0;
        int lastP = 3;
        int checkN = 1;
        if nowP = lastP
            checkN++;
            lastP += lastP



        第幾層,三角形大間隔    當checkN>2時,存在大間隔     最大間隔等於上一層最底層寬度-6
		!!!!用到了!
        int triW = 0;   // 初始值
        if (nowP == lastP) {
            checkN++;
            lastP += lastP;
            if (checkN > 2) {
                triW = ((int)Math.pow(2, checkN - 2) - 1) * 6;          //<----用到了這個
            }
            starN = 2;   // "  *   "、" * *  "、"* * * "每層數量
            starP = 0;   // 輸出了幾層了
        }
        n
        1 0
        2 0
        3 6-0       每三行-6         
        4 18-12-6-0                 
        5 42-36-30-24-18-12-6-0     
        if (nowP % 3 == 0) {
            triW -= 6;
            leftW -= 3;
        }


        // "  *   "、" * *  "、"* * * "每層
        starN = 2   // "  *   "、" * *  "、"* * * "每層數量
        starP = 1   // 輸出了幾層了
        if (starP % 4 == 0) starN *= 2;

        // 星與星間距
        2 2 2       3   3*1
        4
        4 4 4       6   3*2
        4 4 4       9   3*3
        10
        8 8 8       12  3*4
        8 8 8       15  3*5
        16
        16 16 16    18  3*6
        16 16 16    21  3*7
        22
        32 32 32    24  3*8

        int starW = (lastPW - starN * 6 - leftW - triW) / 2;
                    24 - 12 - 3 - 6
         */
	  
		/*
		觀察例子,可以發現,從n=2開始
		左右樹兩邊都是前者各層的形狀,故直接計算好整體左邊和左右兩邊樹間距即可實現了
		*/
        
        int n = in.nextInt();
        int lastPW = (int)Math.pow(2, n - 1) * 6;                   // 最底層寬度
        int leftW = (lastPW - 6) / 2;                               // 左邊寬 每三層-3
        int allP = 3 * (int)Math.pow(2, n - 1);                     // 去除桿子的總層數
        int checkN = 1;                                             // 檢測n,每個n對應的層數
        int starW = 0;                                              // 左右兩邊間距
        int starP = 0;                                              // 統計每新的開始輸出幾層了
        String[] treeData = new String[allP + n];                   // 樹
        for (int i = 1; i <= allP; i++) {
            for (int j = 0; j < leftW; j++) System.out.print(" ");	// 輸出左邊寬
            if (i < 4) {			// 相當於一個初始化的過程
                String putStr = "";
                if (i == 1) {
                    // "  *   "
                    putStr = "  *   ";
                } else if (i == 2){
                    // " * *  "
                    putStr = " * *  ";
                } else {
                    // "* * * "
                    putStr = "* * * ";
                }
                treeData[i - 1] = putStr;
                System.out.print(putStr);
            } else {				// 開始輸出前者的內容
                StringBuilder putStr = new StringBuilder();
                for (int j = 0; j < 2; j++) {	// 左右
                    putStr.append(treeData[starP]);
                    if (j == 0) {
                        // 輸出間距
                        for (int k = 0; k < starW; k++) {
                            putStr.append(" ");
                        }
                    }
                }
                System.out.print(putStr);
                treeData[i - 1] = putStr.toString();
            }
            System.out.println();

            starP++;
            if (i % 3 == 0) {	// 每三層,左邊寬度-3,左右兩邊樹的間距-6
                leftW -= 3;
                starW -= 6;
            }
		  	// 根據checkN知道當前輸出是否到達每個n所處的輸出範圍
            if ((int)Math.pow(2, checkN - 1) * 3 == i) {
                checkN++;
                starP = 0;											// 每個n(checkN),就是新的開始
                if (checkN > 2) {
                    starW = (int)Math.pow(2, checkN - 2) * 6 - 6;	// 左右兩邊樹的間距計算
                }
            }
        }

        // 桿子
        int leftTW = (lastPW / 2) - 1;
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < leftTW; j++) {
                System.out.print(" ");
            }
            System.out.println("*");
        }

    }
}

 

下麵附圖進一步理解:

 

 

 

最後,感謝你閱讀我的文章,感恩!!!

 


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

-Advertisement-
Play Games
更多相關文章
  • 本文由葡萄城技術團隊於博客園原創並首發轉載請註明出處:葡萄城官網,葡萄城為開發者提供專業的開發工具、解決方案和服務,賦能開發者。 項目想做數據可視化,想同時在PC端、手機端查看數據怎麼辦?業務主要關心的數據包括:銷售數據、業績達成、同比、環比,各產品銷售情況及潛客商機、未來收入預測等數據,最好附加人 ...
  • 新媒體時代,廣告樣式越來越豐富。相較於傳統的圖文信息,視頻類廣告更具有直觀性,能夠讓消費者在瞭解產品知識和功能的同時加深對產品的印象。 因此在各類網站或App上投放視頻類廣告是個很好的宣傳方式,但廣告商們如果想在網站上展示視頻廣告,必須確保視頻廣告投放協議與發佈渠道的播放器相容;如果不能相容,廣告商 ...
  • “我苦心鍛煉了三年,我變禿了,也變強了。” —— 琦玉老師 0x00 大綱 0x01 前言 四個月前,我在《你是來找茬的吧?對自己的博客進行調優》一文中探討了以博客的使用者而不是開發者身份去進行優化,究竟能做到何種程度的問題。當時以 Edge 瀏覽器的開發者工具里的 lighthouse 評分和載入 ...
  • 有一朋友想把網頁內容變成PDF下載下來。問我有沒有好辦法。 這還真巧了,咱公司也有這個需求,就是網頁生成合同,然後可以直接列印合同內容。最早吧,就是可以直接列印就好了。 當時為解決完美列印的問題,挺費勁的,當時第三方插件還有BUG(當然把解決放給發給作者了,作者早已經修複了),正經反覆折騰了好一陣子 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 Vue.js是一個基於組件化和響應式數據流的前端框架。當我們在Vue中編寫模板代碼時,它會被Vue編譯器處理並轉換為可被瀏覽器解析的JavaScript代碼。Vue中的模板實際上是HTML標記和Vue指令的組合,它們會被Vue編譯器處理並 ...
  • <!-- 封裝的模板下載和導入按鈕和功能組件--> <template> <span style="margin-left: 10px"> <el-button size="mini" class="el-icon-download" @click="downFiles"> 下載模板</el-but ...
  • 前言 前端開發者若要進行後端開發,大多都會選擇node.js,在node生態下是有大量框架的,其中最受新手喜愛的便是老牌的express.js,接下來我們就從零創建一個express項目。 安裝node 在這裡:https://nodejs.org/dist/v16.14.0/node-v16.14 ...
  • 作者羅錦華,API7.ai 技術專家/技術工程師,開源項目 pgcat,lua-resty-ffi,lua-resty-inspect 的作者。 原文鏈接 為什麼需要 Lua 動態調試插件? Apache APISIX 有很多 Lua 代碼,如何在運行時不觸碰源代碼的情況下,檢查代碼裡面的變數值? ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...