JAVA學習--java數組--打印稀疏數組和稀疏數組的還原

1.題目描述
在這里插入圖片描述
在這里插入圖片描述

2.代碼實現

打印二維數組

public class test04 {public static void main(String args[]){//1.創建一個二維數組11*11,0代表沒有棋子,1代表黑,2代表白棋int[][] array1=new int[11][11];array1[1][2]=1;array1[2][3]=2;//輸出原始的數組System.out.println("輸出原始的數組");for(int[] ints:array1){for(int anint: ints){System.out.print(anint+"\t");}System.out.println();}}
}

在這里插入圖片描述
在這里插入圖片描述在這里插入圖片描述
在這里插入圖片描述

在這里插入圖片描述

如果原始數組懂得0元素太多,則可以壓縮原始數組,使他變成稀疏數組。

public class test04 {public static void main(String args[]){//1.創建一個二維數組11*11,0代表沒有棋子,1代表黑,2代表白棋int[][] array1=new int[11][11];array1[1][2]=1;array1[2][3]=2;//輸出原始的數組
//        System.out.println(array1.length);
//        System.out.println(array1[0].length);System.out.println("輸出原始的數組");for(int[] ints:array1){for(int anint: ints){System.out.print(anint+"\t");}System.out.println();}System.out.println("~~~~~~~~~~~~~~~~~~~~~~");//轉換為稀疏數組保存//獲取有效值的個數int sum=0;for(int i=0;i<array1.length;i++) {for (int j = 0; j < array1[i].length; j++) {if (array1[i][j] != 0) {sum++;}}}System.out.println("輸出有效值的個數:"+sum);//2.創建一個稀疏數組的數組 sum+1代表表頭多了一行,3代表列數總共有3列也就是行列值int[][] array2=new int[sum+1][3];array2[0][0]=11;array2[0][1]=11;array2[0][2]=sum; //大概意思就是原始數組有11行 11列,有效元素是2個//遍歷二維數組,把原始數組將非零的值,存放在稀疏數組里面int cnt=0;for(int i=0;i< array1.length;i++) // 遍歷二維數組的行{for(int j=0;j<array1[i].length;j++)// 遍歷當前行的列{if(array1[i][j]!=0){cnt++;// 記錄非零元素的數量//構造一個新數組array2[cnt][0]=i;// 記錄 array1[i][j] 所在的行號 i。array2[cnt][1]=j;//記錄 array1[i][j] 所在的列號 j。array2[cnt][2]=array1[i][j];//存儲非零元素的值。}}}//輸出稀疏數組
//        System.out.println("稀疏數組");
//        for(int i=0;i< array2.length;i++)
//        {//是打印二維數組 array2 的每一行,但它的結構類似一維數組的打印格式,
//            System.out.println(array2[i][0]+"\t"+array2[i][1]+"\t"+array2[i][2]+"\t");
//        }System.out.println("稀疏數組:");for (int i = 0; i < array2.length; i++) {for (int j = 0; j < array2[i].length; j++) {System.out.print(array2[i][j] + "\t");}System.out.println(); // 換行}}
}

運行效果如下
在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
············································································
**

把稀疏數組還原成原始數組

**

public class test04 {public static void main(String args[]){//1.創建一個二維數組11*11,0代表沒有棋子,1代表黑,2代表白棋int[][] array1=new int[11][11];array1[1][2]=1;array1[2][3]=2;//輸出原始的數組
//        System.out.println(array1.length);
//        System.out.println(array1[0].length);System.out.println("輸出原始的數組");for(int[] ints:array1){for(int anint: ints){System.out.print(anint+"\t");}System.out.println();}System.out.println("~~~~~~~~~~~~~~~~~~~~~~");//轉換為稀疏數組保存//獲取有效值的個數int sum=0;for(int i=0;i<array1.length;i++) {for (int j = 0; j < array1[i].length; j++) {if (array1[i][j] != 0) {sum++;}}}System.out.println("輸出有效值的個數:"+sum);//2.創建一個稀疏數組的數組 sum+1代表表頭多了一行,3代表列數總共有3列也就是行列值int[][] array2=new int[sum+1][3];array2[0][0]=11;array2[0][1]=11;array2[0][2]=sum; //大概意思就是原始數組有11行 11列,有效元素是2個//遍歷二維數組,把原始數組將非零的值,存放在稀疏數組里面int cnt=0;for(int i=0;i< array1.length;i++) // 遍歷二維數組的行{for(int j=0;j<array1[i].length;j++)// 遍歷當前行的列{if(array1[i][j]!=0){cnt++;// 記錄非零元素的數量//構造一個新數組array2[cnt][0]=i;// 記錄 array1[i][j] 所在的行號 i。array2[cnt][1]=j;//記錄 array1[i][j] 所在的列號 j。array2[cnt][2]=array1[i][j];//存儲非零元素的值。}}}//輸出稀疏數組
//        System.out.println("稀疏數組");
//        for(int i=0;i< array2.length;i++)
//        {//是打印二維數組 array2 的每一行,但它的結構類似一維數組的打印格式,
//            System.out.println(array2[i][0]+"\t"+array2[i][1]+"\t"+array2[i][2]+"\t");
//        }System.out.println("稀疏數組:");for (int i = 0; i < array2.length; i++) {for (int j = 0; j < array2[i].length; j++) {System.out.print(array2[i][j] + "\t");}System.out.println(); // 換行}System.out.println("~~~~~~~~~~~~~~~~~~~~~~");System.out.println("輸出還原到的數組:");//讀取稀疏數組,array2[0][0]=11,array2[0][1]=11int[][] array3=new int[array2[0][0]][array2[0][1]];//2.給其中的元素還原它的值,從第一行開始for(int i=1;i< array2.length;i++){//array2中分離的行和列組合一下就是代表有值的元素array3[array2[i][0]][array2[i][1]]=array2[i][2];//定位有值元素的行和列,再把array2的值附上去。}//3.打印System.out.println("輸出還原的數組");for(int[] ints:array3){for(int anInt:ints)//遍歷當前行的列數{System.out.print(anInt+"\t");}System.out.println();}}
}

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/73374.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/73374.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/73374.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java 標準注解(內置注解+元注解)的詳細說明及使用場景

以下是 Java 標準注解&#xff08;內置注解&#xff09;的詳細說明及使用場景&#xff1a; 1. 核心標準注解 (1) Override 用途&#xff1a;標記一個方法覆蓋父類的方法或實現接口的抽象方法。約束&#xff1a; 若方法未正確覆蓋/實現&#xff0c;編譯器會報錯。不能用于字段…

使用Python調用Jenkins Api之獲取構建日志使用說明文檔

簡介 通過 Python 腳本自動化獲取 Jenkins 構建日志&#xff0c;可以實現日志分析、錯誤監控、報告生成等功能。本文檔將介紹以下方法&#xff1a; Python-Jenkins 庫&#xff1a;官方推薦的 Python 客戶端庫 日志分頁與流式處理&#xff1a;應對大日志文件場景 準備工作 …

Day20-前端Web案例——部門管理

目錄 部門管理1. 前后端分離開發2. 準備工作2.1 創建Vue項目2.2 安裝依賴2.3 精簡項目 3. 頁面布局3.1 介紹3.2 整體布局3.3 左側菜單 4. Vue Router4.1 介紹4.2 入門4.3 案例4.4 首頁制作 5. 部門管理5.1部門列表5.1.1. 基本布局5.1.2 加載數據5.1.3 程序優化 5.2 新增部門5.3…

Android java 設計封裝增強型WebView組件

Android java 設計封裝增強型WebView組件&#xff08;兼容Android 4.4&#xff09; * 特性&#xff1a; * 1. 全生命周期管理 * 2. 智能硬件加速 * 3. 鏈式配置API * 4. 安全下載管理 * 5. 全屏視頻支持 public class EnhancedWebView extends WebView {private CustomWebChrom…

vue 點擊放大,圖片預覽效果

背景&#xff1a; 在使用vue框架element組件的背景下&#xff0c;我們對圖片的展示需要點擊放大(單張)&#xff1b;如果是多張圖片&#xff0c;要支持左右滑動查看多張圖片(多張)。 單張圖片放大&#xff0c;el-image圖片組件&#xff0c;或者原生的img標簽。 多張圖片放大&…

HTTP代理的全面解讀:什么是HTTP代理?HTTP代理的工作原理

在互聯網大潮中&#xff0c;每一個請求和返回數據的背后&#xff0c;都離不開傳輸協議的支持&#xff0c;而HTTP協議無疑是最熟悉的網絡通信基礎之一。當我們談到HTTP代理時&#xff0c;它不僅讓瀏覽網絡變得更高效&#xff0c;也為數據采集以及全球性遠程任務提供了解決方案。…

學習筆記--基于Sa-Token 實現Java項目單點登錄+同端互斥檢測

目錄 同端互斥登錄 單點登錄SSO 架構選型 模式二: URL重定向傳播 前后端分離 整體流程 準備工作 搭建客戶端 搭建認證中心SSO Server 環境配置 開放認證接口 啟動類 跨域處理 同端互斥登錄 同端互斥登陸 模塊 同端互斥登錄指&#xff1a;同一類型設備上只允許單地…

本地生活服務APP開發,市場發展全新商業機遇

隨著移動互聯網的快速發展&#xff0c;人們的消費和生活習慣發生了巨大改變&#xff0c;本地生活服務市場迎來了發展爆發期&#xff01;從外賣、團購等&#xff0c;人們越來越依賴通過手機APP解決日常生活中的各種需求。對于企業而言&#xff0c;一款完善、多樣、便捷的本地生活…

當科技業成為系統性壓榨的絞肉機

深夜的硅谷辦公室依然燈火通明&#xff0c;鍵盤敲擊聲此起彼伏。一位程序員在Slack上收到主管的緊急需求&#xff1a;“這個功能明早必須上線。”他苦笑一聲&#xff0c;關掉手機里名為“緩解焦慮”的冥想App——這已是本周第三次被迫服用公司提供的“心靈解藥”。此刻&#xf…

代碼隨想錄算法訓練營第五十六天 | 108.冗余連接 109.冗余連接II

108. 冗余連接 卡碼網題目鏈接&#xff08;ACM模式&#xff09;(opens new window) 題目描述 有一個圖&#xff0c;它是一棵樹&#xff0c;他是擁有 n 個節點&#xff08;節點編號1到n&#xff09;和 n - 1 條邊的連通無環無向圖&#xff08;其實就是一個線形圖&#xff09;…

什么是索引?為什么要使用B樹作為索引數據結構?

MySQL的事務特性 1.原子性:原子性就是這個事件要么執行完,要么沒執行,不會存在中間狀態,與C中華那個加鎖避免多線程競爭是一個道理; 2.一致性:保持事件的操作對象雙方某數據之和是不變的,就以轉賬為例,A轉給B100塊,那么A的余額多100,B的余額就必須少100; 3.隔離性:隔離就是獨…

pyqt5報錯:qt.qpa.plugin: Could not find the Qt platform plugin “xcb“(已解決)

我在使用pyqt庫的時候報錯&#xff1a; qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in \ "/mnt/private_disk/anaconda3/envs/aot-manip/lib/python3.8/site-packages/PyQt5/Qt5/plugins/platforms" even though it was found. This ap…

AI大模型全攻略:原理 · 部署 · Prompt · 場景應用

?? AI大模型全攻略:原理 部署 Prompt 場景應用 本文從基礎原理到實踐部署,再到 Prompt 工程與典型應用案例,全方位解析 AI 大模型的學習路徑與使用方法,適合開發者、產品經理、技術愛好者等不同背景讀者。 ?? 一、什么是 AI 大模型? AI 大模型(Large Language Mo…

2024年MathorCup數學建模D題量子計算在礦山設備配置及運營中的建模應用解題文檔與程序

2024年第十四屆MathorCup高校數學建模挑戰賽 D題 量子計算在礦山設備配置及運營中的建模應用 原題再現&#xff1a; 隨著智能技術的發展&#xff0c;智慧礦山的概念越來越受到重視。越來越多的設備供應商正在向智慧礦山整體解決方案供應商轉型&#xff0c;是否具備提供整體解…

Flink 流處理框架的核心特性

文章目錄 事件時間支持Flink狀態編程一、狀態的類型1. 托管狀態&#xff08;Managed State&#xff09;2. 原始狀態&#xff08;Raw State&#xff09; 二、狀態的管理和容錯 Flink端到端的一致性1、檢查點機制2、冪等3、事務 水位線窗口操作1、窗口類型2、窗口操作的時間語義 …

交換機(access端口)

任務&#xff1a;對access有更深入的理解 通過網盤分享的文件&#xff1a;交換機&#xff08;access&#xff09;.zip 鏈接: https://pan.baidu.com/s/1cMC6Na_1PLo6zOHazFplQQ?pwd23a5 提取碼: 23a5 SW1 <Huawei>sys [Huawei]dis vlan The total number of vlans …

《鳥哥的Linux私房菜基礎篇》---5 vim 程序編輯器

目錄 一、vim程序編輯器的簡介 二、命令模式快捷鍵&#xff08;默認模式&#xff09; 1、光標移動 2、編輯操作 3、搜索與替換 三、插入模式快捷鍵 四、底行模式快捷鍵&#xff08;按&#xff1a;進入&#xff09; 五、高級技巧 1、分屏操作 2、多文件編輯 3、可視化…

AI大白話(四):自然語言處理——AI是如何理解和生成人類語言的?

??引言: 專欄:《AI大白話》 AI大白話(一):5分鐘了解AI到底是什么? AI大白話(二):機器學習——AI是怎么“學習“的? AI大白話(三):深度學習——AI的‘大腦‘是如何構建的? 大家好!歡迎回到"AI大白話"系列。前面我們聊了AI的基本概念、機器學習的原理…

擴展卡爾曼濾波

1.非線性系統的線性化 標準卡爾曼濾波 適用于線性化系統&#xff0c;擴展卡爾曼濾波 則擴展到了非線性系統&#xff0c;核心原理就是將非線性系統線性化&#xff0c;主要用的的知識點是 泰勒展開&#xff08;我另外一篇文章的鏈接&#xff09;&#xff0c;如下是泰勒展開的公式…

安裝unsloth

我在llamafactory微調LLM&#xff0c;簡單測了一些&#xff08;很不精準&#xff09;&#xff0c;加速方法中unsloth比flash_attention速度快了40%&#xff0c;顯存占用減少15%&#xff1b; 創建虛擬環境&#xff1a;conda create -n env_name python3.10, 然后conda activate…