真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

pnum函數(shù)c語言 c語言pnum

計算機C語言中的關(guān)鍵字:union是什么意思?

c語言中的結(jié)構(gòu)(struct)和聯(lián)合(union)簡介。 else pf-next=pi;

成都創(chuàng)新互聯(lián)公司專注于鹿泉網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供鹿泉營銷型網(wǎng)站建設(shè),鹿泉網(wǎng)站制作、鹿泉網(wǎng)頁設(shè)計、鹿泉網(wǎng)站官網(wǎng)定制、微信小程序服務(wù),打造鹿泉網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供鹿泉網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

pi-next=pb;

}

else

{

pb-next=pi;

pi-next=NULL;

}

}

return head;

}

void print(TYPE * head)

{

printf("Number\t\tAge\n");

while(head!=NULL)

{

printf("%d\t\t%d\n",head-num,head-age);

head=head-next;

}

}

main()

{

TYPE * head,*pnum;

int n,num;

printf("input number of node: ");

scanf("%d",n);

head=creat(n);

print(head);

printf("Input the deleted number: ");

scanf("%d",num);

head=delete(head,num);

print(head);

printf("Input the inserted number and age: ");

pnum=(TYPE *)malloc(LEN);

scanf("%d%d",pnum-num,pnum-age);

head=insert(head,pnum);

print(head);

}

[/code:1:8d8ee8c82c]

本例中,print函數(shù)用于輸出鏈表中各個結(jié)點數(shù)據(jù)域值?男尾蝖ead的初值指向鏈表第一個結(jié)點。在while語句中,輸出結(jié)點值后, head值被改變,指向下一結(jié)點。若保留頭指針head, 則應(yīng)另設(shè)一個指針變量,把head值賦予它,再用它來替代head。在main函數(shù)中,n為建立結(jié)點的數(shù)目, num為待刪結(jié)點的數(shù)據(jù)域值;head為指向鏈表的頭指針,pnum為指向待插結(jié)點的指針。 main函數(shù)中各行的意義是:

第六行輸入所建鏈表的結(jié)點數(shù);

第七行調(diào)creat函數(shù)建立鏈表并把頭指針返回給head;

第八行調(diào)print函數(shù)輸出鏈表;

第十行輸入待刪結(jié)點的學號;

第十一行調(diào)delete函數(shù)刪除一個結(jié)點;

第十二行調(diào)print函數(shù)輸出鏈表;

第十四行調(diào)malloc函數(shù)分配一個結(jié)點的內(nèi)存空間, 并把其地址賦予pnum;

第十五行輸入待插入結(jié)點的數(shù)據(jù)域值;

第十六行調(diào)insert函數(shù)插入pnum所指的結(jié)點;

第十七行再次調(diào)print函數(shù)輸出鏈表。

從運行結(jié)果看,首先建立起3個結(jié)點的鏈表,并輸出其值;再刪103號結(jié)點,只剩下105,108號結(jié)點;又輸入106號結(jié)點數(shù)據(jù), 插入后鏈表中的結(jié)點為105,106,108。聯(lián)合“聯(lián)合”也是一種構(gòu)造類型的數(shù)據(jù)結(jié)構(gòu)。 在一個“聯(lián)合”內(nèi)可以定義多種不同的數(shù)據(jù)類型, 一個被說明為該“聯(lián)合”類型的變量中,允許裝入該“聯(lián)合”所定義的任何一種數(shù)據(jù)。 這在前面的各種數(shù)據(jù)類型中都是辦不到的。例如, 定義為整型的變量只能裝入整型數(shù)據(jù),定義為實型的變量只能賦予實型數(shù)據(jù)。

在實際問題中有很多這樣的例子。 例如在學校的教師和學生中填寫以下表格: 姓 名 年 齡 職 業(yè) 單位 “職業(yè)”一項可分為“教師”和 “學生”兩類。 對“單位”一項學生應(yīng)填入班級編號,教師應(yīng)填入某系某教研室。 班級可用整型量表示,教研室只能用字符類型。 要求把這兩種類型不同的數(shù)據(jù)都填入“單位”這個變量中, 就必須把“單位”定義為包含整型和字符型數(shù)組這兩種類型的“聯(lián)合”。

“聯(lián)合”與“結(jié)構(gòu)”有一些相似之處。但兩者有本質(zhì)上的不同。在結(jié)構(gòu)中各成員有各自的內(nèi)存空間, 一個結(jié)構(gòu)變量的總長度是各成員長度之和。而在 “聯(lián)合”中,各成員共享一段內(nèi)存空間, 一個聯(lián)合變量的長度等于各成員中最長的長度。應(yīng)該說明的是, 這里所謂的共享不是指把多個成員同時裝入一個聯(lián)合變量內(nèi), 而是指該聯(lián)合變量可被賦予任一成員值,但每次只能賦一種值, 賦入新值則沖去舊值。如前面介紹的“單位”變量, 如定義為一個可裝入“班級”或 “教研室”的聯(lián)合后,就允許賦予整型值(班級)或字符串(教研室)。要么賦予整型值,要么賦予字符串,不能把兩者同時賦予它。聯(lián)合類型的定義和聯(lián)合變量的說明一個聯(lián)合類型必須經(jīng)過定義之后, 才能把變量說明為該聯(lián)合類型。

一、聯(lián)合的定義

定義一個聯(lián)合類型的一般形式為:

union 聯(lián)合名

{

成員表

};

成員表中含有若干成員,成員的一般形式為: 類型說明符 成員名 成員名的命名應(yīng)符合標識符的規(guī)定。

例如:

union perdata

{

int class;

char office[10];

};

定義了一個名為perdata的聯(lián)合類型,它含有兩個成員,一個為整型,成員名為class;另一個為字符數(shù)組,數(shù)組名為office。聯(lián)合定義之后,即可進行聯(lián)合變量說明,被說明為perdata類型的變量,可以存放整型量class或存放字符數(shù)組office。

二、聯(lián)合變量的說明

聯(lián)合變量的說明和結(jié)構(gòu)變量的說明方式相同, 也有三種形式。即先定義,再說明;定義同時說明和直接說明。以perdata類型為例,說明如下:

union perdata

{

int class;

char officae[10];

};

union perdata a,b; /*說明a,b為perdata類型*/

或者可同時說明為:

union perdata

{

int class;

char office[10];

}a,b;

或直接說明為:

union

{

int class;

char office[10];

}a,b

經(jīng)說明后的a,b變量均為perdata類型。 它們的內(nèi)存分配示意圖如圖7—8所示。a,b變量的長度應(yīng)等于 perdata 的成員中最長的長度, 即等于

office數(shù)組的長度,共10個字節(jié)。從圖中可見,a,b變量如賦予整型值時,只使用了2個字節(jié),而賦予字符數(shù)組時,可用10個字節(jié)。

聯(lián)合變量的賦值和使用

對聯(lián)合變量的賦值,使用都只能是對變量的成員進行。 聯(lián)合變量的成員表示為: 聯(lián)合變量名.成員名 例如,a被說明為perdata類型的變量之后,可使用 a.class a.office 不允許只用聯(lián)合變量名作賦值或其它操作。 也不允許對聯(lián)合變量作初始化賦值,賦值只能在程序中進行? 掛僨康魎得韉氖?一個聯(lián)合變量, 每次只能賦予一個成員值?瘓浠八?一個聯(lián)合變量的值就是聯(lián)合變員的某一個成員值。

[例7.15]設(shè)有一個教師與學生通用的表格,教師數(shù)據(jù)有姓名,年齡,職業(yè),教研室四項。學生有姓名,年齡,職業(yè),班級四項。

編程輸入人員數(shù)據(jù), 再以表格輸出。

[code:1:8d8ee8c82c]

main()

{

struct

{

char name[10];

int age;

補充:你可以自己去電腦編程網(wǎng)看看,那里很多這電腦編程方面的知識

中國物聯(lián)網(wǎng)校企聯(lián)盟技術(shù)部

哪位高手幫我解釋一下 ?

第一句int *pnum=num;

這句聲明是錯誤的??绰暶髡Z句的方法就是從變量名從里往外看,所以pnum是個指針,該指針指向一個int類型的引用,這是非法的。在C++中,引用不能作為數(shù)組元素和指針指向的元素。例如,下面的聲明是非法的:

int a[5]; //error 數(shù)組的元素是引用

int *p; //error p指向一個引用

但是下面的聲明合法:

int b[5];

int (a)[5] = b; //OK 這里a是一個數(shù)組的引用;而不是“數(shù)組的元素是引用”

不過若是只寫int (a)[5];而不初始化也是錯誤的,因為引用必須顯式初始化。

第二句int * refpnum=pnum;是正確的(前提是pnum是int*類型),這里refpnum是個引用,該引用所引的是int*類型的變量。

至于引用指針的實踐作用,我舉一個最簡單的例子:

假設(shè)getPointer函數(shù)需要返回主調(diào)函數(shù)一個地址,該地址存儲的是一個int類型的數(shù)據(jù),那么我們肯定設(shè)計成返回int*變量,但是該函數(shù)又要返回另一個值來表示操作是否成功,可以返回bool類型的變量??墒且粋€函數(shù)無法同時返回兩個數(shù)據(jù),在C語言中,會把函數(shù)設(shè)計成如下:

typedef int bool;

bool getPointer(int **p);

這樣在主函數(shù)中這樣用:

int *p = NULL;

bool bOk = getPointer( p);

然后p中就存儲了getPointer寫入的地址值了,而fOk記錄了函數(shù)是否運行成功。

在C++中,同樣功能的函數(shù)可以這樣設(shè)計:

bool getPointer(int *p);

主函數(shù)中:

int *p = NULL;

bool Fok = getPointer(p);

這和上面的代碼完成同樣的事情。

為方便你,我給你個完整的程序,你可以研究下:

#include iostream

using namespace std;

int globalVar = 24; //24隨便想出的,沒有實際意義

//你的編譯器可能不支持bool和true關(guān)鍵字,你可以用int和1代替

bool getPointer(int *ref) {

ref = globalVar;

return true;

}

int main() {

int *p = NULL;

if(!getPointer(p)) {

//返回了false,這個簡單的程序不會返回false

cout "error" endl;

} else {

//返回了true,成功。進行輸出

cout *p endl;

}

return(0);

}

C語言指針方式

不確定你的輸入輸出是怎樣的,我默認是內(nèi)部有的,僅寫函數(shù)聲明和調(diào)用的部分。

函數(shù)聲明:

void?Count(int*?data,?int?length,?int*?pnum,?int*?nnum)

調(diào)用部分:

int?Data[]?=?{1,0,-,};

int?pnum?=?0,?nnum?=?0;?

Count(Data,?3,?pnum,?nnum);

說明如下:

函數(shù)的第一個參數(shù)是保存這組實數(shù)的數(shù)組。

函數(shù)的第二個參數(shù)是用來傳遞數(shù)組的長度的。

函數(shù)的第三個參數(shù)用來記錄正數(shù)的個數(shù)。

函數(shù)的第四個參數(shù)用來記錄負數(shù)的個數(shù)。

調(diào)用部分的Data僅僅是用來實例的。

大概的函數(shù)體是:

void?Count(int*?data,?int?length,?int*?pnum,?int*?nnum)

{

*pnum?=?0,?*nnum?=?0;

for(int?i?=?0;?i??length;?i++)

{

if(data[i]??0)

*pnum++;

else?if?(data[i]??0)

*nnum++;

}

}


新聞名稱:pnum函數(shù)c語言 c語言pnum
標題網(wǎng)址:http://weahome.cn/article/doppjce.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部