荷甲直播免费观看直播在线_丰满的继牳3中文字幕系列免费_久久婷婷激情精品综合_有码 无码 中文字幕 丝袜_国内外成人激情视频_亚洲乱码中文字幕234_韩国理论福利片午夜_亚洲一区二区三区高清精油按摩_日本韩国欧美三级在线_在线Ⅴ片免费观看视频

知ing

大學(xué)C/C++語言程序設(shè)計實驗教程

陽小華 羅晨暉 編 / 電子工業(yè)出版社

王大膽 上傳

查看本書


實驗11 ?指針綜合實驗

任務(wù) ?使用指針編寫綜合應(yīng)用程序

1.某班有M個學(xué)生,開設(shè)三門課程(高數(shù)、英語、計算機(jī))的成績,編程輸入學(xué)生的學(xué)號及三門課程的成績,求各人的平均分,并顯示。

參考程序如下:

#include "stdio.h"

#define M 5

struct student

{

????int num;

????int score[3]; ?

????float average;

}stu[M];

main( )

{

???struct student *p;

???for(p=stu;p<stu+M;p++)

???{

??scanf("%d %d %d %d",&(p->num),&(p->score[0]),&(p->score[1]),&(p->score[2]));

??????p->average=(p->score[0]+p->score[1]+p->score[2])/3.0;

???}

???printf("平均分為\n\n");

???for(p=stu;p<stu+M;p++)

???{ ??printf("%5d%5d%5d%5d%7.2f\n",p->num,p->score[0],p->score[1],p->score[2],p->average);

???}

}

2.編寫一函數(shù),求一個字符串的長度。在main(?)函數(shù)中輸入字符串,并輸出其長度。

參考程序如下:

#include <stdio.h>

#include <string.h>

int len(char *s)

{

????int k=0;

????for(;*s!='\0';s++)

??????k++;

????return k;

}

main( )

{

????char str1[80],*p=str1;

????scanf("%s",str1);

????printf("\nlength of the string is:%d",len(str1));

}

3.從鍵盤輸入一行文字,找出其中大寫字母、小字字母、數(shù)字及其他字符各有多少?

參考程序如下:

#include <stdio.h>

main( )

{

????int i,j,k,m;

????char *p,a[100];

????p=a;

????i=j=k=m=0;

????scanf("%s",p);

????for(;*p!='\0';p++)

????{

??????if(*p>=97&&*p<=122 ) ?i++;

??????else if(*p>=65&&*p<=90) ?j++;

??????else if(*p>=48&&*p<57) ?k++;

??????else ?m++;

????}

????printf("Lower case char:%d,Up case cahr:%d,number char:%d,other char:%d",i,j,k,m);

}

4.利用指針編寫程序,實現(xiàn)對數(shù)組進(jìn)行從小到大的排序(冒泡法)。

參考程序如下:

#include<stdio.h>

main( )

{

????int a[10];

????int *p,t,k,i,j;

????p=a;

????for(i=0;i<10;i++)

????{ scanf("%d",p);p++; }

p=a;

????for(i=0;i<9;i++)

{ ??k=i;

????????for(j=i+1;j<10;j++)

if(p[k]>p[j])k=j;

????????if(k!=i)

{ t=p[k];p[k]=p[i];p[i]=t;}

}

????for(i=0;i<10;i++)

printf("%5d",p[i]);

}

5100人圍成一圈,從第1個人開始,每數(shù)到3的人出圈,問最后一個出圈的人是哪個?

參考程序如下:

#include ?<stdio.h>

void main( )

{

????int a[100],i,n,k,*p;

????p=a;

????for(i=0;i<100;i++)

??????*(p+i)=i+1;

????n=100;

????i=k=0;

????while(n>1)

????{

????????if(*(p+i)!=0) ?k++;

????????if(k==3) ?{*(p+i)=0;k=0;n--;}

????????i++;

????????if(i==100) ?i=0;

????}

????while(*p==0) ?p++;

????printf("the last is %d\n",*p);

}

實驗12 ?結(jié)構(gòu)體、共用體與枚舉

任務(wù)1 ?結(jié)構(gòu)體、共用體與枚舉構(gòu)造數(shù)據(jù)類型的定義與使用

1.運(yùn)行下面程序,熟悉結(jié)構(gòu)體變量及指向結(jié)構(gòu)體變量指針的使用。

#include<stdio.h>

void main( )

{

????struct xs

????{ int num;

????????char name[20];

????????float score;

????}stu1={001,"Zhang san",90.5};

????struct xs stu2,*p;

????stu2=stu1;

????printf("%d %s %f\n",stu2.num,stu2.name,stu2.score);

????p=&stu2;

????printf("%d %s %f\n",p->num,p->name,p->score);

}

運(yùn)行結(jié)果為:

1 Zhang san 90.500000

1 Zhang san 90.500000

2.運(yùn)行下面程序,并分析指向結(jié)構(gòu)體數(shù)組的指針變量的使用,理解指針與結(jié)構(gòu)體數(shù)組的關(guān)系及結(jié)構(gòu)體成員的引用方式。

#include<stdio.h>

struct xs

{ ?int num;

???char name[20];

???char sex;

???int age;

}stu[3]={{10101,"Li Lin",'M',18},

?????????{10102,"Zhang Fun",'M',19},

?????????{10104,"Wang Min",'F',20}};

main( )

{

???struct xs *p;

???for(p=stu;p<stu+3;p++)

???printf("%d %s %c %d\n",p->num,p->name,p->sex,p->age);

}

運(yùn)行結(jié)果為:

10101 Li Lin M 18

10102 Zhang Fun M 19

10104 Wang Min F 20

思考:printf("%d%s%c%d\n",p->num,p->name,p->sex,p->age);如用結(jié)構(gòu)體數(shù)組元素的方式表示,該引用方式如何表示?

代碼修改如下:

#include<stdio.h>

struct xs

{ ?int num;

???char name[20];

???char sex;

???int age;

}stu[3]={{10101,"Li Lin",'M',18},

?????????{10102,"Zhang Fun",'M',19},

?????????{10104,"Wang Min",'F',20}};

main( )

{

???struct xs *p;

???int i;

???for(i=0;i<3;i++)

???printf("%d %s %c %d\n",stu[i].num,stu[i].name,stu[i].sex,stu[i].age);

}

3.以下程序通過定義學(xué)生結(jié)構(gòu)體數(shù)組,存儲了若干名學(xué)生的學(xué)號、姓名和3門課的成績。函數(shù)fun(?)的功能是將存放學(xué)生數(shù)據(jù)的結(jié)構(gòu)體數(shù)組,按照姓名的字典序(從小到大)排序。

請在程序的下劃線處填入正確的內(nèi)容并把下劃線刪除, 使程序得出正確的結(jié)果。

#include ?<stdio.h>

#include ?<string.h>

struct student {

????long ?sno;

????char ?name[10];

????float ?score[3];

};

void fun(struct student ?a[], int ?n)

{

????/**********found**********/

????struct student ?t;

????int ?i, j;

????/**********found**********/

????for (i=0; i<?n-1 ; i++)

???????for (j=i+1; j<n; j++)

????/**********found**********/

???????if (strcmp(a[i].name,a[j].name)?> 0)

???????{ ?t = a[i]; ??a[i] = a[j]; ?a[j] = t; ?}

}

void main( )

{ ?struct student ?s[4]={{10001,"ZhangSan", 95, 80, 88},{10002,"LiSi", 85, 70, 78},{10003,"CaoKai", 75, 60, 88}, {10004,"FangFang", 90, 82, 87}};

???int ?i, j;

???printf("\n\nThe original data :\n\n");

???for (j=0; j<4; j++)

???{ ?printf("\nNo: %ld ?Name: %-8s ?????Scores: ?",s[j].sno, s[j].name);

??????for (i=0; i<3; i++) ?printf("%6.2f ", s[j].score[i]);

??????printf("\n");

???}

???fun(s, 4);

???printf("\n\nThe data after sorting :\n\n");

???for (j=0; j<4; j++)

???{ ?printf("\nNo: %ld ?Name: %-8s ?????Scores: ?",s[j].sno, s[j].name);

??????for (i=0; i<3; i++) ?printf("%6.2f ", s[j].score[i]);

??????printf("\n");

???}

}

?

4.下面程序通過對學(xué)生學(xué)號、姓名、出生年月信息的輸入與輸出,分析并理解指向結(jié)構(gòu)體類型變量的正確使用方法,以及結(jié)構(gòu)體嵌套定義。

#include <stdio.h>

#include <stdlib.h> /*使用malloc( )需要包括該頭文件*/

struct data/*定義結(jié)構(gòu)體*/

{

????int day,month,year;

};

struct stu/*定義結(jié)構(gòu)體*/

{

????char name[20];

????long num;

????struct data birth; /*嵌套的結(jié)構(gòu)體類型成員*/

} ;

void main(?) /*定義main( ) 函數(shù)*/

{

????struct stu *xs; ???????????????????????/*定義結(jié)構(gòu)體類型指針*/

????xs=(struct stu *)malloc(sizeof(struct stu)); /*為指針變量分配安全的地址*/

????printf("Input name,number,year,month,day:\n");

????scanf("%s",xs->name); ???????????????/*輸入學(xué)生姓名、學(xué)號、出生年月日*/

????scanf("%ld", &xs->num);

????scanf("%d %d %d", &xs->birth.year,&xs->birth.month,&xs->birth.day);

????printf("\nOutput name,number,year,month,day\n" );/*打印輸出各成員項的值*/

????printf("%s%ld %5d// %d// %d\n",xs->name,xs->num,xs->birth.year,

????xs->birth.month,xs->birth.day);

}

運(yùn)行結(jié)果如下:

Input name,number,year,month,day:

HanTingyu 22 1985 11 1

HanTingyu22 1985//11//1(書上多空了很多的空格)

5.驗證下面程序,熟悉共用體變量的使用。

#include ?<stdio.h>

union ab{

??????int a;

??????char b[2];

};

void main( )

{

??????union ab t;

??????t.a=0x1234;

??????printf("t.a=%x\nt.b[1]=%x\nt.b[0]=%x\n",t.a,t.b[1],t.b[0]);

}

程序輸出結(jié)果如下:

t.a=1234

t.b[1]=12

t.b[0]=34

任務(wù)2 ?鏈表的定義與使用

給定程序中,函數(shù)fun(?)的功能是將帶頭節(jié)點的單向鏈表結(jié)點數(shù)據(jù)域中的數(shù)據(jù)從小到大排序。即若原鏈表結(jié)點數(shù)據(jù)域從頭至尾的數(shù)據(jù)為104、28、6,排序后鏈表結(jié)點數(shù)據(jù)域從頭至尾的數(shù)據(jù)為2、4、6、8、10。

請在程序的下劃線處填入正確的內(nèi)容并將下劃線刪除, 使程序得出正確的結(jié)果。

#include ?<stdio.h>

#include ?<stdlib.h>

#define ???N ???6

typedef struct node {

????int ?data;

????struct node ?*next;

} NODE;

void fun(NODE ?*h)

{ ?NODE ?*p, *q; ???int ?t;

???/**********found**********/

???p =??h->next ?;

???while (p) {

???/**********found**********/

???????q = ?p->next ?;

???????while (q) {

???/**********found**********/

???????????if (p->data ?> ?q->data)

???????????{ ?t = p->data; ?p->data = q->data; ?q->data = t; ?}

???????????q = q->next;

???}

???p = p->next;

??}

}

NODE *creatlist(int ?a[])

{ ?NODE ?*h,*p,*q; ???????int ?i;

???h = (NODE *)malloc(sizeof(NODE));

???h->next = NULL;

???for(i=0; i<N; i++)

???{ ?q=(NODE *)malloc(sizeof(NODE));

??????q->data=a[i];

??????q->next = NULL;

??????if (h->next == NULL) ?h->next = p = q;

??????else ???{ ?p->next = q; ?p = q; ??}

???}

??????return ?h;

}

void outlist(NODE ?*h)

{ ?NODE ?*p;

???p = h->next;

???if (p==NULL) ?printf("The list is NULL!\n");

???else

???{ ?printf("\nHead ?");

??????do

??????{ ?printf("->%d", p->data); p=p->next; ?}

??????while(p!=NULL);

??????printf("->End\n");

???}

}

main( )

{ ?NODE ?*head;

???int ?a[N]= {0, 10, 4, 2, 8, 6 };

???head=creatlist(a);

???printf("\nThe original list:\n");

???outlist(head);

???fun(head);

???printf("\nThe list after sorting :\n");

???outlist(head);

}

?


查看更多