c語言數組教案
1. c語言 數組內數字比較大小
#include<stdio.h>
voidmain()
{
inta[10]={10,2,3,4,5,6,9,8,7,1};
inti,j,t;
for(j=0;j<10;j++)
for(i=0;i<10-1-j;i++)
if(a[i]>a[i+1])/*由小到大,由大到小時改為<*/
{
t=a[i];
a[i]=a[i+1];
a[i+1]=t;
}
for(i=0;i<10;i++)
printf("%d",a[i]);
}
(1)c語言數組教案擴展閱讀
C語言數組長度獲取
#include<stdio.h>
#include<stdlib.h>
#defineGET_ARRAY_LEN(array,len){len=(sizeof(array)/sizeof(array[0]));}
//定義一個帶參數的宏,將數組長度存儲在變數len中
intmain()
{
chara[]={'1','2','3','4'};
intlen;
GET_ARRAY_LEN(a,len)
//調用預定義的宏,取得數組a的長度,並將其存儲在變數len中
printf("%d ",len);
system("pause");
return0;
}
2. c語言插入數組元素(數組)
C語言中,數組是一組連續的相同類型的數據集合。 所以要在數組中插入元素,需要按照以下步驟:
1、找到插入點;
2、將插入點所在元素,及之後的所有元素,都向後移動一個單位;
3、將插入點賦值為要插入的元素。
以固定位置插入,代碼舉例如下:
#include<stdio.h>
voidinsert(int*a,intn,inti,intv)
//將長度為n的數組a,下標為i的位置插入值為v的元素。插入後,數組長度為n+1.
{
intj;
for(j=n-1;j>=i;j--)//將i及以後的後移一位。由於是固定位置插入,所以不需要查找插入位置。
a[j+1]=a[j];
a[i]=v;//插入元素。
}
intmain()
{
inta[5]={1,3,6,7};/五個元素數組,初始化四個值。
inti;
insert(a,4,2,5);//將5插入到a[2]位置。
for(i=0;i<5;i++)
printf("%d",a[i]);//輸出結果,為13567
return0;
}
3. c語言二維數組實例
以下是幾個簡單的C語言二維數組實例代碼
輸出第n行的楊輝三角形:
#include<stdio.h>
voidmain()
{
inti,j,n; inta[100][100]={0};//定義一個二維數組。
scanf("%d",&n);
a[0][1]=1;
for(i=1;i<n;i++)
for(j=1;j<i+2;j++)
a[i][j]=a[i-1][j]+a[i-1][j-1];
for(i=0;i<n;i++)
{
for(j=1;j<i+2;j++)
printf("%d ",a[i][j]);
printf(" ");
}
}樣例輸入:5
樣例輸出:
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
將一個n*m矩陣的行和列互換,並輸出:
#include<stdio.h>
voidmain()
{
inti,j,n,m;
inta[100][100],b[100][100];
scanf("%d%d",&n,&m);
for(i=0;i<n;i++)
for(j=0;j<m;j++)
{
scanf("%d",&a[i][j]);
b[j][i]=a[i][j];
}
printf("輸出原矩陣: ");
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
printf("%d ",a[i][j]);
printf(" ");
}
printf("輸出互換後的矩陣: ");
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
printf("%d ",b[i][j]);
printf(" ");
}樣例輸入:
2 3
15 46 47
16 3 48
樣例輸出:
輸出原矩陣:
15 46 47
16 3 48
輸出互換後的矩陣:
15 16
46 3
47 48
4. c語言一維數組
#include "stdio.h"
#define N 30
void main()
{
int grades[N]; //所有人的分數
int upAverage[N]; //超過平均分的學生序號
int unPass[N]; //不及格的學生序號
int nNum = 0; //學生總人數
int nUpAve = 0; //超過平均分的人數
int totGrade = 0; //總分
int n50,n60,n70,n80,n90; //各個分數段人數
double average; //平均分
int i;
//讀入成績
while (1){
scanf("%d",&grades[nNum]);
if (grades[nNum]<0) break;
totGrade += grades[nNum];
nNum++;
}
average = totGrade*1.0/nNum;
//統計各個分數段人數
n50 = n60 = n70 = n80 = n90 = 0;
for (i=0; i if (grades[i] >= average) upAverage[nUpAve++] = i;
if (grades[i] < 60) unPass[n50++] = i;
else if (grades[i] < 70) n60++;
else if (grades[i] < 80) n70++;
else if (grades[i] < 90) n80++;
else n90++;
}
//結果輸出
printf("不及格人數: %d\n",n50);
printf("不及格學生序號:");
for (i=0; i printf("\n成績在全班平均分及平均分之上的學生人數: %d\n",nUpAve);
printf("這些學生序號:");
for (i=0; i printf("\n以直方圖方式統計各分數段的學生人數及所佔的百分比\n");
printf("\n分數段 \t 學生人數\t圖形");
printf("\n <60 \t %2d(%.0lf%%) \t", n50, n50*100.0/nNum); for (i=0; i printf("\n 60-69 \t %2d(%.0lf%%) \t", n60, n60*100.0/nNum); for (i=0; i printf("\n 70-79 \t %2d(%.0lf%%) \t", n70, n70*100.0/nNum); for (i=0; i printf("\n 80-89 \t %2d(%.0lf%%) \t", n80, n80*100.0/nNum); for (i=0; i printf("\n >=90 \t %2d(%.0lf%%) \t", n90, n90*100.0/nNum); for (i=0; i printf("\n");
}
5. C語言中如何定義數組
數組定義的三種方式
1、第一種
int []a = newint[5];
a[0] = 10;
2、第二種
int []c = newint[]{1,2,3};
3、第三種
int []i ={1,2,3,4};
4、錯誤的寫法
int []i1 = [1,2,3,4];
System.out.println(Arrays.toString(c));
5、總之,具體的元素不能被【】包裹。【】包裹的應該是數組的數量。
(5)c語言數組教案擴展閱讀
數組的注意事項:
1、 數組中每個元素的數據類型必須相同,對於inta[4];,每個元素都必須為 int。
2、 數組長度 length最好是整數或者常量表達式,
3、 訪問數組元素時,下標的取值范圍為 0 ≤ index < length,
參考資料
網路-數組
6. 關於c語言中數組作為函數參數的函數之間調用問題
1、新建一個數組作為參數項目,如圖所示:
7. c語言字元數組使用方法
c語言字元數組使用方法
導語:字元數組是一個存儲字元的數組,而字元串是一個用雙括弧括起來的以'/0'結束的字元序列,下面就由我為大家介紹一下c語言字元數組使用方法,希望對大家有所幫助!
1、字元數組的定義與初始化
字元數組的初始化,最容易理解的方式就是逐個字元賦給數組中各元素。
char str[10]={ 'I',' ','a','m',' ',『h','a','p','p','y'};
即把10個字元分別賦給str[0]到str[9]10個元素
如果花括弧中提供的字元個數大於數組長度,則按語法錯誤處理;若小於數組長度,則只將這些字元數組中前面那些元素,其餘的元素自動定為空字元(即 '/0' )。
2、字元數組與字元串
在c語言中,將字元串作為字元數組來處理。(c++中不是)
在實際應用中人們關心的是有效字元串的長度而不是字元數組的長度,例如,定義一個字元數組長度為100,而實際有效字元只有40個,為了測定字元串的實際長度,C語言規定了一個「字元串結束標志」,以字元'/0'代表。如果有一個字元串,其中第10個字元為'/0',則此字元串的有效字元為9個。也就是說,在遇到第一個字元'/0'時,表示字元串結束,由它前面的字元組成字元串。
系統對字元串常量也自動加一個'/0'作為結束符。例如"C Program」共有9個字元,但在內存中佔10個位元組,最後一個位元組'/0'是系統自動加上的。(通過sizeof()函數可驗證)
有了結束標志'/0'後,字元數組的長度就顯得不那麼重要了,在程序中往往依靠檢測'/0'的位置來判定字元串是否結束,而不是根據數組的`長度來決定字元串長度。當然,在定義字元數組時應估計實際字元串長度,保證數組長度始終大於字元串實際長度。(在實際字元串定義中,常常並不指定數組長度,如char str[ ])
說明:''代表ASCII碼為0的字元,從ASCII碼表中可以查到ASCII碼為0的字元不是一個可以顯示的字元,而是一個「空操作符」,即它什麼也不幹。用它來作為字元串結束標志不會產生附加的操作或增加有效字元,只起一個供辨別的標志。
對C語言處理字元串的方法由以上的了解後,再對字元數組初始化的方法補充一種方法――即可以用字元串常量來初始化字元數組:
char str[ ]={"I am happy"}; 可以省略花括弧,如下所示
char str[ ]="I am happy";
注意:上述這種字元數組的整體賦值只能在字元數組初始化時使用,不能用於字元數組的賦值,字元數組的賦值只能對其元素一一賦值,下面的賦值方法是錯誤的
char str[ ];
str="I am happy";
不是用單個字元作為初值,而是用一個字元串(注意:字元串的兩端是用雙引號「」而不是單引號『'括起來的)作為初值。顯然,這種方法更直觀方便。(注意:數組str的長度不是10,而是11,這點請務必記住,因為字元串常量"I am happy"的最後由系統自動加上一個'/0')
因此,上面的初始化與下面的初始化等價
char str[ ]={'I',' ','a','m',' ','h','a','p','p','y','/0'};
而不與下面的等價
char str[ ]={'I',' ','a','m',' ','h','a','p','p','y'};
前者的長度是11,後者的長度是10.
說明:字元數組並不要求它的最後一個字元為'/0',甚至可以不包含'/0',向下面這樣寫是完全合法的。
char str[5]={'C','h','i','n','a'};
++++++++
可見,用兩種不同方法初始化字元數組後得到的數組長度是不同的。
#include
void main(void)
{
char c1[]={'I',' ','a','m',' ','h','a','p','p','y'};
char c2[]="I am happy";
int i1=sizeof(c1);
int i2=sizeof(c2);
printf("%d",i1);
printf("%d",i2);
}
結果:10 11
3、字元串的表示形式
在C語言中,可以用兩種方法表示和存放字元串:
(1)用字元數組存放一個字元串
char str[ ]="I love China";
(2)用字元指針指向一個字元串
char* str="I love China";
對於第二種表示方法,有人認為str是一個字元串變數,以為定義時把字元串常量"I love China"直接賦給該字元串變數,這是不對的。
C語言對字元串常量是按字元數組處理的,在內存中開辟了一個字元數組用來存放字元串常量,程序在定義字元串指針變數str時只是把字元串首地址(即存放字元串的字元數組的首地址)賦給str。
兩種表示方式的字元串輸出都用
printf("%s",str);
%s表示輸出一個字元串,給出字元指針變數名str(對於第一種表示方法,字元數組名即是字元數組的首地址,與第二種中的指針意義是一致的),則系統先輸出它所指向的一個字元數據,然後自動使str自動加1,使之指向下一個字元...,如此,直到遇到字元串結束標識符 " /0 "。
4、對使用字元指針變數和字元數組兩種方法表示字元串的討論
雖然用字元數組和字元指針變數都能實現字元串的存儲和運算,但它們二者之間是有區別的,不應混為一談。
4.1、字元數組由若干個元素組成,每個元素放一個字元;而字元指針變數中存放的是地址(字元串/字元數組的首地址),絕不是將字元串放到字元指針變數中(是字元串首地址)
4.2、賦值方式:
對字元數組只能對各個元素賦值,不能用以下方法對字元數組賦值
char str[14];
str="I love China"; (但在字元數組初始化時可以,即char str[14]="I love China";)
而對字元指針變數,採用下面方法賦值:
char* a;
a="I love China";
或者是 char* a="I love China"; 都可以
4.3、對字元指針變數賦初值(初始化):
char* a="I love China";
等價於:
char* a;
a="I love China";
而對於字元數組的初始化
char str[14]="I love China";
不能等價於:
char str[14];
str="I love China"; (這種不是初始化,而是賦值,而對數組這樣賦值是不對的)
4.4、如果定義了一個字元數組,那麼它有確定的內存地址;而定義一個字元指針變數時,它並未指向某個確定的字元數據,並且可以多次賦值。
5、字元串處理函數
5.1
char *strcat(char *str1,const char *2 );
char *strcat(char *strDestination,const char *strSource );
功能:函數將字元串str2 連接到str1的末端,並返回指針str1
註:連接前兩個字元串的後面都有一個' /0 ',連接時將字元串1後面的 ' /0 『去掉,只在新串最後保留一個 ' /0 『
5.2
char *strcpy(char *str1,const char *2 );
char *strcpy(char *strDestination,const char *strSource );
功能:復制字元串strSource中的字元到字元串strDestination,包括空值結束符。返回值為指針strDestination。
註:1、「字元數組1」必須寫成數組名形式,「字元串2"可以是字元數組名,也可以是一個字元串常量
2、復制時連同字元串後面的 ' /0 ' 一起復制到數組1中
3、不能用賦值語句直接將一個字元串常量或者字元數組直接賦給一個字元數組(同普通變數數組是一樣的),而只能用strcpy函數處理。
4、可以用strcpy函數將字元串2中的前若干個字元復制到字元數組1中去。
;8. c語言數組的定義
C語言支持一維數組和多維數組。如果一個數組的所有元素都不是數組,那麼該數組稱為一維數組。
在C語言中使用數組必須先進行定義,一維數組的定義方式為:類型說明符; 數組名 ;[常量表達式]。
其中,類型說明符是任一種基本數據類型或構造數據類型。數組名是用戶定義的數組標識符,方括弧中的常量表達式表示數據元素的個數,也稱為數組的長度。例如:
int a[10]; /* 說明整型數組a,有10個元素 */
float b[10], c[20]; /* 說明實型數組b,有10個元素,實型數組c,有20個元素 */
char ch[20]; /* 說明字元數組ch,有20個元素 */
對於數組類型說明應注意以下幾點:
1、數組的類型實際上是指數組元素的取值類型。對於同一個數組,其所有元素的數據類型都是相同的。
2、數組名的書寫規則應符合標識符的書寫規定。
3、數組名不能與其它變數名相同。例如:
int a;
float a[10];
是錯誤的。
4、方括弧中常量表達式表示數組元素的個數,如a[5]表示數組a有5個元素。但是其下標從0開始計算。因此5個元素分別為a[0], a[1], a[2], a[3], a[4]。
5、不能在方括弧中用變數來表示元素的個數,但是可以是符號常數或常量表達式。例如:
#define FD 5
// ...
int a[3+2],b[7+FD];
是合法的。但是下述說明方式是錯誤的。
int n=5;
int a[n];
6、允許在同一個類型說明中,說明多個數組和多個變數。例如:
int a,b,c,d,k1[10],k2[20];
(8)c語言數組教案擴展閱讀:
C語言是一門通用計算機編程語言,廣泛應用於底層開發。C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。
盡管C語言提供了許多低級處理的功能,但仍然保持著良好跨平台的特性,以一個標准規格寫出的C語言程序可在許多電腦平台上進行編譯,甚至包含一些嵌入式處理器(單片機或稱MCU)以及超級電腦等作業平台。
二十世紀八十年代,為了避免各開發廠商用的C語言語法產生差異,由美國國家標准局為C語言制定了一套完整的美國國家標准語法,稱為ANSI C,作為C語言最初的標准。[1]目前2011年12月8日,國際標准化組織(ISO)和國際電工委員會(IEC)發布的C11標準是C語言的第三個官方標准,也是C語言的最新標准,該標准更好的支持了漢字函數名和漢字標識符,一定程度上實現了漢字編程。
C語言是一門面向過程的計算機編程語言,與C++,Java等面向對象的編程語言有所不同。
其編譯器主要有Clang、GCC、WIN-TC、SUBLIME、MSVC、Turbo C等。