iOS階段學習第六天筆記(數組)

来源:http://www.cnblogs.com/androidshouce/archive/2016/07/19/5683435.html
-Advertisement-
Play Games

iOS學習(C語言)知識點整理 一、整型數組 1)概念:一組類型相同,空間連續分佈的數據。 2)int a[10] int 型裡面有10個元素,數組的名字叫a, a還是數組的首地址 。 3)引用數組中的元素 a[i]:數組名+下標,下標從0開始 。 4)數組元素個數剛好與數組長度相當叫完全初始化。 ...


                                                                                              iOS學習(C語言)知識點整理

一、整型數組

 1)概念:一組類型相同,空間連續分佈的數據。

 2)int a[10] int 型裡面有10個元素,數組的名字叫a, a還是數組的首地址 。

 3)引用數組中的元素 a[i]:數組名+下標,下標從0開始 。

 4)數組元素個數剛好與數組長度相當叫完全初始化。

 5)數組的遍歷即訪問數組裡面的所有元素。

 6)元素的地址 &a[0] 取地址符+數組名+下標

 7)遍歷輸入,訪問不能越界,越界編譯器檢查不了,有較大的安全風險

 8)int 數組的sizeof等於數組長度乘4

 9)部分初始化後面省略部分全部賦值為0.

10)int a[5]={0} ;int a[5]={}; 部分初始化,全零補齊數組

11)數組的最大下標為數組的長度減一  例如:int a[]={1,2,3,4,5}  len=sizeof(a)/sizeof(int); 最大下標為 len-1。

12)數組長度[ ]裡面只能是常量,符號常量

13)數組的初始化

    ①. Int list[5]={2,13,58,55,19};//一般寫法

    ②. Int list[5]={6,17};//只對前兩個元素賦值

    ③. Int list[5]={[3]=25,[4]=51};//對指定的元素賦值,這裡為第三個和第四個

    ④. Int list[]={11,12,13}.//正確,右邊的元素確定,則個數可以省略這裡為3個。

    ⑤. Int list[];//錯誤,編譯器無法知道應該分配多少的存儲空間

    ⑥. Int list[5]; list ={17,18,19,20,21};//錯誤,只能在定義數組時這樣進行初始化

    ⑦. Int list[‘A’]={1,2,3};//正確,相當於是ages[65]

    ⑧. Int count=5;int list[count];//如果不進行初始化,則這種寫法正確,編譯器不會報錯為其分配20個位元組的存儲空間,

         list[0]=1; list[1]=2;可以像這樣對數組的元素進行賦值,但是2,3,4等元素的值時不確定的。 

    ⑨. 而int count=5;int list[count]={1,2,3,4,5};//這種寫法是錯誤的,在定義數組時對數組進行初始化,元素的個數必須為

         常量或者不寫,不能是一個變數

      

14)斐波拉契數列  1,1 ,2 ,3 ,5 ,8 ,13 ,21 ,34...

實現代碼:

複製代碼
 1 int main(){
 2    int arr[20]={};
 3     for (int i=0; i<20; i++) {
 4         if(i<=1)
 5             arr[i]=1;
 6          else
 7           arr[i]=arr[i-1]+arr[i-2];
 8     }
 9     for (int i=0; i<20; i++) {
10         printf("%d ",arr[i]);
11     }
12     return 0;
13  }
複製代碼

二、排序

1)選擇排序:每次從無序數列選擇一個最小的,放在有序隊列的後面

      例如:int a[]={12,3,556,0,9,78};

      1. 0]3,556,12,9,78

      2. 0,3],556,12,9,78

      3. 0,3,9]12,556,78

      4. 0,3,9,12]556,78

      5. 0,3,9,12,78]556

實現代碼:

複製代碼
 1  int main(){
 2     int a[]={12,3,556,0,9,78};
 3     int len = sizeof(a)/sizeof(int);
 4     int k;//紀錄最小數的下標
 5     int temp;
 6     //一共要排len-1次
 7     for(int i=0;i<len-1;i++){
 8         //從a[i]~a[len-1]裡面找出最小的值,放到a[i]的位置
 9         k=i;
10         for(int j=i+1;j<len;j++){
11             if(a[j]<a[k]){
12                 k=j;
13             }
14         }
15 
16         //a[k]和a[i]做一次交換
17         if(k!=i){
18             temp = a[k];
19             a[k] = a[i];
20             a[i] = temp;
21         }
22     }
23 
24     for(int i=0;i<len;i++){
25         printf("%d ",a[i]);
26     }
27       return 0;
28    }
複製代碼

 2)冒泡排序:大數往下沉,小數往上浮

  比較相鄰的元素。如果第一個比第二個大,就交換他們兩個。

  int a[]={12,3,556,0,9,78};

 一輪比較,需要5次

 1.1  [3,12],556,0,9,78

 1.2  3,[12,556],0,9,78

 1.3  3,12,[0,556],9,78

 1.4  3,12,0,[9,556],78

 1.5  3,12,0,9,[78,556]->一輪結束,最大的一個數沉入底部排序

 實現代碼:

複製代碼
 1 int main()
 2 {
 3     int a[]={12,3,556,0,9,78};
 4     int temp;
 5     int len = sizeof(a)/sizeof(int);
 6     //排len-1次
 7     for(int i=0;i<len-1;i++){
 8         //無序的數列:a[0]~a[len-1-i],逐對比較
 9         //前面>後面,就交換
10         //i=0,最後一對: a[len-2],a[len-1]
11         for(int j=0;j<len-1-i;j++){
12             if(a[j]>a[j+1]){
13                 temp = a[j];
14                 a[j] = a[j+1];
15                 a[j+1] = temp;
16             }
17         }
18     }
19 
20     for(int i=0;i<len;i++){
21         printf("%d ",a[i]);
22     }
23     return 0;
24 }
複製代碼

3)插入排序

 int a[]={12,3,556,0,9,78};

 初始化 12[3,556,0,9,78]

 1. 3,12[556,0,9,78]

 2. 3,12,556[0,9,78]

 3. 0,3,12,556[9,78]

 4. 0,3,9,12,556,[78]

 5. 0,3,9,12,78,556

 {12,33,556,0,9,78}

 實現代碼:

複製代碼
 1  int main()
 2  {
 3     int a[]={12,3,556,0,9,78};
 4     int len =  sizeof(a)/sizeof(int);
 5     int insert = 0;
 6     //一共要比較len-1次
 7     for(int i=0;i<len-1;i++){
 8         //把a[i+1] 插入到 前面有序數列a[0]~a[i]
 9         insert = a[i+1];
10         for(int j=0;j<=i;j++){
11             if(a[j]>insert){
12                 //插入a[j]這個位置
13                 //後移a[j]~a[i]後移一個
14                 printf("insert %d,pos = %d\n",insert,j);
15                 for(int k=i;k>=j;k--){
16                     a[k+1]=a[k];
17                 }
18                 //插入位置填入insert
19                 a[j]= insert;
20                 break;
21             }
22         }
23 
24         for(int ii=0;ii<len;ii++){
25             printf("%d ",a[ii]);
26         }
27         printf("\n");
28     }
29 
30     for(int ii=0;ii<len;ii++){
31         printf("%d ",a[ii]);
32     }
33     return 0;
34 }
複製代碼

三、字元數組

 1)計算字元數組的有效長度用strlen(數組名)

2)實例:

  小寫轉大寫 實現代碼:

複製代碼
 1 int main(){
 2   char str[10]={'h','e','l','l','o'};
 3   int len = (int)strlen(str);
 4    //小寫轉大寫
 5      for(int i=0;i<len;i++){
 6          if(str[i]>='a'&&str[i]<='z'){
 7              str[i] = str[i]- ('a'-'A');
 8          }
 9      }
10   printf("%s",str);
11  
12   return 0;
13 }
複製代碼

四、二維數組

 1)實例:

利用二維數組列印楊輝三角

 1

 1  1

 1  2  1

 1  3  3  1

 1  4  6  4  1

 1  5  10 10 5 1

 實現代碼:

複製代碼
 1  int main(){
 2     int a[10][10];
 3     for(int i=0;i<10;i++){
 4         for(int j=0;j<=i;j++){
 5             if(j==0||i==j)
 6                a[i][j]=1;
 7              else
 8                 a[i][j]=a[i-1][j]+a[i-1][j-1];
 9         }
10     }
11 
12     for(int i=0;i<10;i++){
13         for(int j=0;j<=i;j++){
14             printf("%5d",a[i][j]);
15         }
16         printf("\n");
17     }
18     return 0;
19 }
複製代碼

五、不使用第三方變數實現數據交換

實現代碼:

複製代碼
1 int main(){
2   int a=20,b=30;
3   a=a+b;
4   b=a-b;
5   a=a-b;
6   printf("a=%d;b=%d",a,b);
7 
8   return 0;
9 }
複製代碼

 



如果您覺得閱讀完本文對您有幫助,請點一下“推薦”按鈕,您的推薦將是我寫作的最大動力;本文版權歸作者和博客園共有,來源網址:http://www.cnblogs.com/ChinaKingKong/歡迎各位轉載,但未經作者本人同意,轉載文章之後必須在文章頁面明顯位置給出作者和原文連接否則保留追究法律責任的權利。

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

-Advertisement-
Play Games
更多相關文章
  • 我們先來看一道題目 1 2 3 4 var write = document.write; write("hello"); //1.以上代碼有什麼問題 //2.正確操作是怎樣的 1 2 3 4 var write = document.write; write("hello"); //1.以上代碼有 ...
  • 摘要: 之前項目用過Less,現在負責的項目也要使用,所以就總結下Less,也方便以後查看。本文主要是講瀏覽器端如何使用Less。 簡介: LESS是一種由Alexis Sellier設計的動態層疊樣式表語言。LESS 是開源的,其第一個版本由Ruby寫成,但在後續的版本當中,Ruby逐漸被替換為J ...
  • 所謂的作用域,可以簡單理解為一個可以讀、寫的範圍(區域),有些js經驗的同學可能會說:"js沒有塊級作用域",js除了全局作用域外,只有函數可以創建作用域。作用域的一個好處就是可以隔離變數。 我們通過一些例子來幫助我們理解js中的作用域。 如果對作用域一點不瞭解的同學可能會說 alert的是1或者報 ...
  • 水平居中 若為行內元素,對其父元素用text-align:center即可; 若為塊元素(無浮動),則一般有兩種方法可實現對其的水平居中,一為margin:0 auto;二為通過css計算函數calc; 垂直居中 若為行內元素,一般對其父元素用line-height:{height}即可,若為圖片元 ...
  • 第0章 關於本書 1, 本書要用到一個工具函數————$$(),它可以讓我們更容易獲取和遍歷所有匹配特定css選擇符的dom元素: 2, 以下實現一個效果: 3, 檢查屬性是否存在: 檢測多個屬性: 檢測某個具體的屬性值是否支持: 第1章 前言 1, 不用-ms-border-radius和-o-b ...
  • 路由 通常HTTP URL的格式是這樣的: http://host[:port][path] http表示協議。 host表示主機。 port為埠,可選欄位,不提供時預設為80。 path指定請求資源的URI(Uniform Resource Identifier,統一資源定位符),如果URL中沒 ...
  • 寫在開篇: 浮動屬性的設計初衷,只是為了實現文本環繞效果! 時刻牢記這一點,才能正確使用浮動。 浮動元素的特征: 1.浮動元素脫離文檔流。 2.浮動元素周圍的外邊距不會合併。 3.浮動元素具有包裹性。 4.浮動元素具有破壞性。 下麵這段代碼,能夠驗證上述的四個特征,按提示操作即可。 1 <!DOCT ...
  • 一,代碼。 二,輸出。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...