实验4 数组
实验任务1
//task1_1 #include <stdio.h> #define N 4 int main() { int a[N] = {2, 0, 2, 2}; char b[N] = {'2', '0', '2', '2'}; int i; printf("sizeof(int) = %d\n", sizeof(int)); printf("sizeof(char) = %d\n", sizeof(char)); printf("\n"); //输出数组a中每个元素的地址、值 for (i = 0;i<N; ++i) printf("%p: %d\n", &a[i], a[i]); printf("\n"); //输出数组名a和b对应的值 printf("a = %p\n", a); printf("b = %p\n", b); return 0; }

1.int 型数组a,在内存中是连续存放的,每个元素占用1个内存单元
2.char型数组b,在内存中是连续存放的,每个元素占用1个内存单元
3.数组名a对应的值,和&a[0]是一样的
数组名b对应的值,和&b[0]是一样的
//task1_2 #include <stdio.h> #define N 2 #define M 3 int main() { int a[N][M] = {{1, 2, 3},{4, 5, 6}}; char b[N][M] = {{'1', '2', '3'},{'4', '5', '6'}}; int i, j; //输出二维数组a中每个元素的地址和值 for(i = 0; i<N; ++i) for(j = 0; j<M; ++j) printf("%p: %d\n", &a[i][j], a[i][j]); printf("\n"); //输出二维数组a中每个元素的地址和值 for(i = 0; i<N; ++i) for(j = 0; j<M; ++j) printf("%p: %c\n", &b[i][j], b[i][j]); return 0; }

1.int型二维数组a,在内存中是“按行连续存放的”,每个元素占用2个内存单元
2.char型二维数组b,在内存中是“按行连续存放的”,每个元素占用1个内存单元
实验任务2
//task2 #include<stdio.h> int days_of_year(int year, int month, int day); //函数声明 int main() { int year, month,day; int days; while(scanf("%d%d%d", &year, &month,&day) != EOF) // 按下Ctr1+Z终止 { days = days_of_year(year, month, day); // 函数调用 printf("%4d-%02d-%02d是这一年的第%d天. \n\n",year, month, day, days) ; } return 0; } int days_of_year(int year, int month, int day) { int s=0,i; if(year%4==0&&year%100!=0||year%400==0) { int a[12]={31,29,31,30,31,30,31,31,30,31,30,31}; for(i=0;i<month-1;i++) s=s+a[i]; s=s+day; } else { int a[12]={31,28,31,30,31,30,31,31,30,31,30,31}; for(i=0;i<month-1;i++) s=s+a[i]; s=s+day; } return s; }

//task3 #include <stdio.h> #define N 5 void input(int x[],int n); void output(int x[],int n); double average(int x[],int n); void sort(int x[],int n); int main() { int scores[N]; double ave; printf("录入%d个分数:\n", N); input(scores, N); printf("\n输出课程分数: \n"); output(scores, N); printf("\n课程分数处理:计算均分、排序...\n"); ave = average(scores, N); sort(scores, N); printf("\n输出课程均分: %.2f\n", ave); printf("\n输出课程分数(高->低):\n"); output(scores, N); return 0; } void input(int x[],int n) { int i; for(i=0; i<n; ++i) scanf("%d",&x[i]); } void output(int x[],int n) { int i; for(i=0; i<n; ++i) printf("%d ",x[i]); printf("\n"); } double average(int x[],int n) { int sum=0,i; double ave; for(i=0;i<n;i++) sum=sum+x[i]; ave=sum*1.0/N; return ave; } void sort(int x[],int n) { int i,j,t; for(j=1;j<n;j++) { for(i=0;i<n;i++) { if(x[i]<x[i+1]) { t=x[i]; x[i]=x[i+1]; x[i+1]=t; } } } }

实验任务4
//task4 #include <stdio.h> void dec2n(int x,int n); //函数声明 int main() { int x; printf("输入一个十进制整数: "); scanf("%d",&x); dec2n(x,2); // 函数调用:把x转换成二进制输出 dec2n(x,8); // 函数调用:把x转换成 八进制输出 dec2n(x,16); //函数调用:把x转换成十六进制输出 return 0; } void dec2n(int x,int n) { char a[100]; int i,k,j=0; for(i=0;x!=0;i++,j++) { k=x%n; if(k>=10) a[i]='A'+k-10; else a[i]='0'+k; x=x/n; } for(i=j-1;i>=0;i--) printf("%c",a[i]); printf("\n"); }

实验任务5
//task5 #include<stdio.h> #define N 30 int main() { int a[N][N]; int n; int i, j, k; printf("Enter n: "); while(scanf("%d",&n)!=EOF) { for (i = 0; i < n; i++) { for (j = 0; j < n; j++) { if(i<j) { a[i][j]=i+1; } else { a[i][j]=j+1; } } } for (i=0;i<n;i++) { for (j=0;j<n;j++) printf("%d ", a[i][j]); printf("\n"); } printf("\nEnter n: "); } return 0; }

实验任务6
//task6 #include <stdio.h> #define N 80 int main() { int i,j; char t; char views1[N]="hey,c,i hate u."; char views2[N]="hey,c,i love u."; printf("otiginal views:\n"); printf("views1:"); for(i=0;i<N;i++) printf("%c",views1[i]); printf("\nviews2:"); for(j=0;j<N;j++) printf("%c",views2[j]); printf("\n\n"); printf("swapping...\n\n"); for(i=0;i<N;i++) for(j=0;j<N;j++) if(i=j) { t=views1[i]; views1[i]=views2[i]; views2[i]=t; } printf("views1:"); for(i=0;i<N;i++) printf("%c",views1[i]); printf("\nviews2:"); for(j=0;j<N;j++) printf("%c",views2[j]); printf("\n"); return 0; }

实验任务7
//task7 #include <stdio.h> #include <string.h> #define N 5 #define M 20 void bubble_sort(char str[][M],int n); int main() { char name[][M]={"Bob","Bill","Joseph","Taylor","George"}; int i; printf("输出初始名单:\n"); for(i=0;i<N;i++) printf("%s\n",name[i]); printf("\n排序中...\n"); bubble_sort(name,N); printf("\n按字典序输出名单:\n"); for(i=0;i<N;i++) printf("%s\n",name[i]); return 0; } void bubble_sort(char str[][M],int n) { int j,i; char t[10]; for(j=1;j<n;j++) { for(i=0;i<n-j-1;i++) { if(strcmp(str[i],str[i+1])>0) { strcpy(t,str[i]); strcpy(str[i],str[i+1]); strcpy(str[i+1],t); } } } }


浙公网安备 33010602011771号