學習筆記5-C語言-數組

數組:

什么是數組:  相同類型變量的組合,是一種批量定義變量的方式
定義:  類型 數組名[數組變量數量];int arr[5];
使用:數組名[下標];arr[0];數組下標從零開始,范圍:0~數量-1
遍歷:從頭到尾過一遍,與for循環相配合,使用循環變量作為數組的下標
初始化: 類型 數組名[數量] = {1,2,3,4,5...}1、數組與普通變量一樣,默認值是隨機的,為了安全起見要對數組進行初始化2、初始化數據過多時,編輯器會產生警告并且丟棄多余的數據3、初始化數據不足時,編輯器會自動補04、初始化只能逐個賦值,不能整體賦值5、這種初始化的語法,只能在定義數組時使用6、初始化時,數組的長度可以省略,編譯器會自動統計數據的個數,并告訴數組計算數組長度:sizeof(arr)/sizeof(arr[0])練習1:定義一個長度為十的數組,并初始化,計算出數組內的最大值,最小值,平均值
#include<stdio.h>
int main(int argc,const char* argv[])
{float arr[10]={};int i;float sum,MIN,MAX;printf("輸入10個數");for(i=0;i<10;i++){scanf("%f",&arr[i]);	}MAX=arr[0];MIN=arr[0];sum=arr[0];for(i=1;i<10;i++){if(MAX<arr[i]){MAX=arr[i];	}	if(MIN>arr[i]){MIN=arr[i];	}sum+=arr[i];}printf("%.1f %.1f %.1f",MAX,MIN,sum/10);return 0;
}
	練習2:定義一個長度為十的數組,并初始化,進行升序排序
#include<stdio.h>int main(int argc,const char* argv[])
{int a[10];int i,j,c;printf("輸入10個數");for(i=0;i<10;i++){scanf("%d",&a[i]);	}for(i=0;i<10;i++){for(j=i+1;j<10;j++){if(a[i]>a[j]){c=a[i];a[i]=a[j];a[j]=c;}}}for(i=0;i<10;i++){printf("%d ",a[i]);	}return 0;
}

數組越界:

為了程序的運算效率不會檢查數組下標
數組越界結果:1、一切正常2、段錯誤3、臟數據練習3:定義一個長度10的數組,找出第二大的值,不允許排序
#include<stdio.h>int main(int argc,const char* argv[])
{int a[10]={6,10,5,3,4,8,9,7,1,2};int max=a[0]>a[1]?a[0]:a[1];int secmax=a[0]>a[1]?a[1]:a[0];for(int i=2;i<10;i++){if(a[max]<=a[i]){secmax=max;	max=i;}else if(a[secmax]<=a[i]){secmax=i;	}}printf("%d %d",a[max],a[secmax]);
}

二維數組:

一維數組當作把變量變成一排,通過編號來訪問數組
二維數組相當于把變量變成矩陣,通過行號列號訪問定義:類型 數組名[行數][列數];int arr[3][5];[0,0][0,1][0,2][0,3][0,4][1,0][1,1][1,2][1,3][1,4][2,0][2,1][2,2][2,3][2,4]
使用:數組名[行下標][列下標]行下標:0~行數-1列下標:0~列數-1arr[1][2]=100;
遍歷:一般需要與雙層內循環配合,一般外層循環負責遍歷行,內層循環遍歷列for(int i =0;i<3;i++){for(int j=0;j<5;j++){printf("%d",a[i][j]);}printf("\n");}初始化: 類型 數組名[行數][列數]={{第一行數據},{第二行數據},{},...};練習4: 定義一個5*5的二維數組,找出最大值的坐標
#include<stdio.h>int main(int argc,const char* argv[])
{int a[5][5]={{9,8,5,7,6},{2,5,8,7,4},{3,69,8,5,4},{3,5,8,7,4},{3,6,98,4,2}}	;int maxi=0;int maxj=0;for(int i=0;i<5;i++){for(int j=0;j<5;j++){if(a[maxi][maxj]<a[i][j]){maxi=i;maxj=j;}}}printf("(%d,%d)",maxi,maxj);
}
練習5:輸入兩個正整數m,n(1<=m<=61<=n<=6),輸入數組arr[m][n]的每個元素,然后計算各元素之和,
統計數組中非零元素個數,計算出所有元素的平均值,在統計大于平均值元素的個數。
#include<stdio.h>int main(int argc,const char* argv[])
{int m,n;printf("mn\n");scanf("%d%d",&m,&n);float a[m][n];float sum=0;printf("a\n");int num0=0,num1=0;for(int i=0;i<m;i++){for(int j=0;j<n;j++){scanf("%f",&a[i][j]);sum += a[i][j];if(a[i][j]!=0){num0++;	}}}float avg=((float)sum)/(m*n);for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(a[i][j]>avg){num1++;	}}}printf("和=%.1f 非零個數=%d 平均值=%.1f 大于平均值個數=%d",sum,num0,avg,num1);}
練習6:定義一個5*5的二維數組并初始化,找出最小值下標,計算該坐標周邊所有元素之和
#include<stdio.h>int main(int argc,const char* argv[])
{int a[5][5]={{5,8,0,7,6},{2,5,8,2,4},{3,69,8,5,4},{3,5,8,7,4},{3,6,98,4,2}}	;int mini=0;int minj=0;for(int i=0;i<5;i++){for(int j=0;j<5;j++){if(a[mini][minj]>a[i][j]){mini=i;minj=j;}}}int sum=0;if(mini == 0 && minj ==0){sum=a[0][1]+a[1][1]+a[1][0];	}else if(mini == 0 && minj ==4){sum=a[0][3]+a[1][3]+a[1][4];	}else if(mini == 4 && minj ==4){sum=a[4][3]+a[3][3]+a[3][4];	}else if(mini == 4 && minj ==0){sum=a[4][1]+a[3][1]+a[3][0];	}else if(mini == 0){sum=a[0][minj-1]+a[0][minj+1]+a[1][minj-1]+a[1][minj]+a[1][minj+1];	}else if(mini == 4){sum=a[4][minj-1]+a[4][minj+1]+a[3][minj-1]+a[3][minj]+a[3][minj+1];	}else if(minj == 0){sum=a[mini-1][0]+a[mini+1][0]+a[mini-1][1]+a[mini][1]+a[mini+1][1];	}else if(minj == 4){sum=a[mini-1][4]+a[mini+1][4]+a[mini-1][3]+a[mini][3]+a[mini+1][3];	}else{sum=a[mini-1][minj-1]+a[mini-1][minj]+a[mini-1][minj+1]+a[mini][minj-1]+a[mini][minj+1]+a[mini+1][minj-1]+a[mini+1][minj]+a[mini+1][minj+1];	}printf("%d",sum);
}

變長數組:

定義數組時使用變量作為數組的長度,在編譯期間,數組長度是不確定的,當執行到該數組的定義語句時
才確定它的長度,一旦確定后就無法更改長度直到程序結束。優點:可以根據實際情況來確定數組長度,達到節約內存的目的缺點:不能初始化練習7:顯示N層楊輝三角
#include<stdio.h>int main(int argc,const char* argv[])
{int N;printf("N=");scanf("%d",&N);int a[N][N];for(int i=0;i<N;i++){for(int j=0;j<N;j++){a[i][j]=0;	}}a[0][0]=1;for(int i=1;i<N;i++){a[i][0]=1;for(int j=1;j<N;j++){a[i][j]=a[i-1][j-1]+a[i-1][j];	}}for(int i=0;i<N;i++){for(int j=0;j<N;j++){a[i][j]>0 && printf("%d",a[i][j]);}printf("\n");}}

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

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

相關文章

學習筆記6-小項目-走迷宮、推箱子

獲取方向鍵的功能&#xff1a;使用getch.h頭文件中的getch函數 1、把windows中的getch.h頭文件放到共享文件夾中 2、終端輸入 cd /media/sf_GONGXIANG進入共享文件夾 3、sudo cp getch.h /usr/include 4、cd /usr/include/ 5、sudo chmod r getch.h頭文件中的getch函數 time.h…

學習筆記7-C語言-進制轉換、原返補、位運算、函數

進制轉換 為什么要使用二、八進制、十六進制&#xff1f;因為現在的CPU只能識別高低兩種電流&#xff0c;因此只能對二進制數據進行運算二進制數據雖然可以直接被cpu識別&#xff0c;但不方便人們書寫、記錄&#xff0c;所以把二進制數據轉換成八進制是為了方便記錄在文件中。…

學習筆記8-作業

作業1&#xff1a;實現一個函數&#xff0c;判斷一個整數是否是素數&#xff0c;調用該函數來顯示出100~10000之間的所有素數 #include<stdio.h> #include<stdbool.h> #include<math.h> bool is_sushu(int num) {for(int i2;i<sqrt(num);i){if(num%i0)re…

學習筆記9-C語言-傳參、類型限定符、遞歸

函數傳參&#xff1a; 1、形參變量屬于它所在的函數&#xff0c;出了該函數就不能使用 2、實參與形參之間都是以賦值的形式進行數據傳遞&#xff08;值傳遞&#xff09; 3、return 其實是把返回值數據放置到一個公共的區域&#xff08;函數和函數調用者&#xff09;&#xff0…

Oracle創建視圖實現獲取當前數據所在的頁數,這里以每頁2條數據分頁

摘要&#xff1a;Oracle創建視圖實現獲取當前數據所在的頁數&#xff0c;這里以每頁2條數據分頁&#xff0c;詳細請看&#xff1a; 一&#xff1a; DROP VIEW MIP.TB_CMS_FLGTINFO_D_VIEW;/* Formatted on 2014/12/4 8:35:36 (QP5 v5.115.810.9015) */ CREATE OR REPLACE FOR…

學習筆記10-C語言-小項目-五子棋

小項目&#xff1a; 需要的數據 1、定義棋盤的二維數組 2、定義變量用于記錄下棋的坐標 3、定義角色 黑棋 O 白棋 * 空位業務邏輯&#xff1a; 是否需要對數據初始化 for(;;) {1、清屏、顯示棋盤2、落子坐標是否合法、該位置是否有棋子3、判斷是否五子連珠4、交換角色5、顯示…

學習筆記11-C語言-指針

什么是指針&#xff1a; 指針是一種特護的數據類型&#xff0c;使用它可以定義指針變量&#xff0c;指針變量存儲的是整型數據&#xff0c;代表內存的編號&#xff0c;通過這個編號可以訪問到對應內存。為什么使用指針 1、函數與函數之間是相互獨立的&#xff0c;但是有些時候…

學習筆記12-C語言-堆內存、字符串

什么是堆內存&#xff1a; 是進程中的一個內存段&#xff08;text\data\bss\heap\stack&#xff09;&#xff0c;由程序猿手動控制。 特點是足夠大&#xff0c;缺點是使用麻煩為什么要使用堆內存&#xff1a; 1、隨著程序的復雜&#xff0c;數據會越來越多。 2、其他的內存段…

學習筆記13-C語言-字符串函數、緩沖區

字符串的常用函數: #include<string.h> size_t strlen(const char* s); 功能&#xff1a;計算字符串長度&#xff0c;但是結果不包括\0 返回值&#xff1a;返回字符串中字符的個數size_t str_len(const char* str) {assert(NULL ! str);const char* tmp str;while(*tmp…

Oracle數據庫里面查詢字符串類型的字段不為空和為空的SQL語句:

摘要&#xff1a;近期項目中&#xff0c;在做高級查詢的時候有個條件是根據選擇的字段&#xff0c;然后再選擇字段的值為空和不為空做查詢&#xff0c;在寫SQL語句的時候費了很長時間&#xff0c;現在記錄一下&#xff0c;方便日后查看&#xff1a; 一&#xff1a;查詢字符串類…

學習筆記14-C語言-小項目-通訊錄

通訊錄&#xff1a; 要求&#xff1a; 姓名&#xff0c;性別、電話&#xff0c;最多儲存50個聯系人 功能&#xff1a;1、添加聯系人2、按名字刪除聯系人3、按姓名修改聯系人信息4、查找聯系人&#xff0c;可通過電話&#xff0c;名字查找&#xff0c;支持模糊查找5、顯示所有聯…

學習筆記15-C語言-預處理指令、條件編譯、頭文件

預處理指令&#xff1a; 程序猿編寫的代碼不是標準C代碼&#xff0c;并不能被真正的編譯器索編譯&#xff0c;需要一段程序把代碼翻譯一下。 翻譯的過程叫做預處理&#xff0c;被翻譯的代碼叫做預處理指令&#xff0c;以#開頭的都是預處理指令查看預處理的過程&#xff1a;gcc…

學習筆記16-C語言-小項目-使用Makefile完成2048

Makefile: Makefile是一系列編譯指令組成的可執行文本&#xff0c;也叫做編譯腳本。 在終端執行make命令會自動執行Makefile腳本中的編譯命令&#xff0c; 而且它還可以根據文件的最后修改時間來判斷哪些文件是否需要重新編譯、哪些文件不需要重新編譯&#xff0c;從而大大提高…

學習筆記17-C語言-結構、聯合、枚舉

結構&#xff1a; struct 結構是由程序猿自己設計的一種數據類型&#xff0c;用于描述一個事務的各項數據&#xff0c;由若干個不同的基礎數據類型組成。設計結構&#xff1a;struct 結構體名{類型 成員名&#xff1b;...}&#xff1b;定義結構體變量struct 結構體名 變量名&a…

Maven 3.0.5 安裝和配置:

摘要&#xff1a;現在的Web項目越來越多的都用maven管理了&#xff0c;所以我也抽時間學習學習&#xff0c;為了趕上時代&#xff01; 一&#xff1a;首先到maven官網&#xff1a;http://maven.apache.org/&#xff0c;然后選擇相應的版本下載&#xff0c;我這里下載的是maven…

學習筆記18-C語言-文件

文件的分類&#xff1a; 文本文件&#xff1a; 存儲的是ASCII碼值的二進制 二進制文件&#xff1a; 存儲的是數據的補碼文件IO&#xff1a; FILE *fopen(const char *path, const char *mode); 功能&#xff1a;打開或者創建文件 path&#xff1a;文件的路徑 mode&#x…

使用INNER JOIN ON 多表關聯查詢,獲取指定用戶下指定權限的資源SQL:

摘要&#xff1a;最近在看一個開源框架&#xff0c;其中用戶&#xff0c;角色&#xff0c;資源&#xff0c;這塊我感覺比較重要&#xff0c;所以就自己也模仿著寫了下&#xff0c;其中在獲取指定用戶下的權限資源的時候遇到問題了&#xff0c;開始時&#xff0c;我首先想到的方…

Maven學習記錄之maven基本操作命令,maven本地工廠的創建,maven骨架的生成,以及在eclipse中創建maven工程:...

摘要&#xff1a;今天又學習了一下maven&#xff0c;之前是下載并安裝和配置好了maven的環境&#xff0c;今天主要學習的內容包括&#xff1a;maven本地工廠的創建&#xff0c;maven骨架的生成命令&#xff0c;maven在dos下創建maven工程&#xff0c;以及在eclipse中創建mavne工…

Oracle中通過游標執行帶參數的存儲過程實現解析CLOB字段內的xml字符串:

摘要&#xff1a;近來之前的項目數據出現了問題&#xff0c;原因是由于之前在設計數據庫的時候把時間字段設置成了字符串格式&#xff0c;所以給后期的數據操作帶來了很大的麻煩&#xff0c;這里提醒一下各位程序猿&#xff0c;以后在開發項目的時候時間字段一定要是時間字段&a…

Eclipse中使用Checkstyle,checkstyle插件檢查java代碼的自定義配置文件:

摘要&#xff1a;近來項目組在搞代碼檢查&#xff0c;所以領導讓把checkstyle這個插件搞明白&#xff0c;現在我把我們寫的自定義的checkstyle.xml文件記錄一下&#xff0c;以便大家可以一起使用&#xff1a; 一&#xff1a;要使用checkstyle插件在eclipse中檢查java代碼&…