色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

為什么很少有人按列去遍歷訪問二維數組呢?

學益得智能硬件 ? 來源:學益得智能硬件 ? 2023-02-12 09:47 ? 次閱讀

poYBAGPoReuAZSOOAAFbl1gz_lg854.jpg

分享一道360的C語言筆試題。x是一個行列均為1000的二維數組,下面代碼運行效率最高的是哪個?

二維數組大家都很熟悉,正常人遍歷二維數組都是一行一行來的,為什么很少有人按列去遍歷?

這道筆試題其實考察的就是遍歷效率的問題。

選項A,j是行,i是列,很顯然 x[i][j] 是按列訪問,先是第一列第一個元素,然后第一列第二個元素,以此類推。

pYYBAGPoRdWAVHvyAAC5aBaWhVM911.jpg

選項B和選項C都存在按列訪問。

只有選項D,屬于正常的按行遍歷。

那么問題來了,為什么二維數組按行遍歷比按列遍歷來的快?

這個涉及的問題就太多了,得從CPU高速緩存講起。

e3189b6e-a9e3-11ed-bfe3-dac502259ad0.png

CPU處理速度很快,但是訪問內存太慢,嚴重影響了機器運行效率。

于是就出現了高速緩存。

從名字應該能看出,訪問它速度確實快。

當CPU發出內存訪問請求時,會首先查看緩存內是否有請求的數據,如果有,直接返回,如果沒有,就要先把內存中的數據載入緩存,再把它返回給處理器

由于緩存比內存貴很多,所以它的大小一般都以KB或者MB為單位,如果是一級緩存,那就更小了。

題目中的二維數組大小接近4M,CPU在訪問的時候,緩存先從內存抓取數據,而且一般都是抓取相鄰整個數據塊,簡單點理解,就是當前行以及后面的部分數據,這也符合內存訪問局部性特征。

如果二維數組按列遍歷,就需要不斷的抓取內存的數據,降低程序效率,這也將會失去緩存的意義。






審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19265

    瀏覽量

    229671
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10855

    瀏覽量

    211605
  • C語言
    +關注

    關注

    180

    文章

    7604

    瀏覽量

    136710

原文標題:為什么二維數組都是一行一行訪問?

文章出處:【微信號:學益得智能硬件,微信公眾號:學益得智能硬件】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    二維數組按照某進行重新排序

    來到這邊很久了,也從來沒自己發過帖。今天面試,出了一個對二維數組按照某進行重新排序。小弟本來對數組這方面不是特別熟悉,想了半天結果沒做出
    發表于 03-09 22:22

    怎么求二維數組均值啊

    `怎么、行求得二維數組的均值啊`
    發表于 09-06 12:45

    二維數組循環更新程序

    程序實現了把生成的一數組更新二維數組功能。基本實現了LabVIEW二維
    發表于 10-13 13:20

    任意指定排序2數組

    本帖最后由 ltoad 于 2015-12-9 23:11 編輯 輸入為一個二維數組A,數不定要求以指定進行排序,比如指定第0,
    發表于 12-09 23:02

    C語言二維數組的定義和引用

    線性排列的。如何在一存儲器中存放二維數組,可有兩種方式:一種是行排列, 即放完一行之
    發表于 07-12 08:55

    二維數組冒泡排序

    Labview中對于一數組可以直接排序,但如果是二維數組時,特別是字符串類型二維數組,某一
    發表于 09-30 16:06

    請問C語言怎么實現在二維數組里循環遍歷

    怎么用C語言實現在二維數組里循環遍歷
    發表于 03-17 04:35

    C語言程序設計教程之二維數組如何應用二維數組的資料概述

    本文檔的主要內容詳細介紹的是C語言程序設計教程之二維數組如何應用二維數組的資料概述主要內容包括了:1 了解二維
    發表于 10-26 16:48 ?3次下載

    螺旋遍歷二維數組漫畫講解

    來自公眾號:程序員小灰 第天 什么意思?我們來舉個例子,給定下面這樣一個二維數組: 我們需要從左上角的元素1開始,按照順時針進行螺旋遍歷
    的頭像 發表于 11-26 14:01 ?1750次閱讀

    二維數組數組指針以及指針數組

    二維數組數組指針以及指針數組
    的頭像 發表于 08-16 09:02 ?2655次閱讀

    C語言—二維數組介紹

    定義一個兩行三二維數組,總共有6個元素
    的頭像 發表于 09-11 14:51 ?902次閱讀
    C語言—<b class='flag-5'>二維</b><b class='flag-5'>數組</b>介紹

    二維數組存儲最小元素是怎么實現的?

    二維數組存儲最小元素是怎么實現的?? 在計算機編程中,數組是一種非常重要的數據結構之一。它用于存儲一系列相同類型的變量,這些變量被放入單一的數組中并通過一個唯一的編號(稱為
    的頭像 發表于 09-13 11:17 ?532次閱讀

    python怎么創建二維數組

    它們的優缺點和一些常見的操作。 使用嵌套列表創建二維數組: 嵌套列表是Python中創建二維數組最簡單和最基本的方法之一。每個內部的列表都代表了一行或者一
    的頭像 發表于 11-21 15:10 ?3736次閱讀

    python如何定義二維數組

    在Python中,可以通過使用列表嵌套的方式來定義二維數組。具體步驟如下: Step 1: 創建一個空的二維列表 要創建一個空的二維數組
    的頭像 發表于 11-21 15:12 ?1768次閱讀

    將一數組轉為二維python

    過程。接下來,我將為你詳盡、詳實、細致地介紹四種常用的方法。 方法一:使用列表推導式(List Comprehension) 這是一種簡單而又優雅的方法,可以快速將一數組轉換為二維數組
    的頭像 發表于 11-23 14:54 ?5442次閱讀
    主站蜘蛛池模板: 青娱国产区在线| 国产福利一区二区精品| 亚洲一二三产品区别在哪里| 色宅男午夜电影网站| 日本高清不卡码无码v亚洲| 男女边吃奶边做边爱视频| 两百磅美女| 脔到她哭H粗话HWWW男男动漫| 久久99热只有频精品| 好爽胸大好深好多水| 国产在线观看的| 国外经典三级| 精品无码国产自产在线观看水浒传| 国偷自产视频一区二区99| 国内卡一卡二卡三免费网站| 精品96在线观看影院| 久久vs国产综合色| 久久久免费热线精品频| 么公在浴室了我的奶| 欧美xxxav| 青青操久久| 天天爽夜夜爽8888视频精品| 无止侵犯高H1V3无止侵犯| 无码成A毛片免费| 亚洲色综合中文字幕在线| 伊人久久国产精品| 18videosex性欧美黑色| 99在线观看视频免费| caoporn超碰| 国产精品大陆在线视频| 国内精品久久人妻无码HD浪潮| 久久精品免视看国产| 棉签和冰块怎么弄出牛奶视频 | 又硬又粗又大一区二区三区视频| 亚洲片在线观看| 69日本xxⅹxxxxx18| 成人短片迅雷下载| 国产色婷亚洲99精品AV| 久久久久久久网站| 青草国产超碰人人添人人碱| 天美传媒在线观看完整高清|