实验四
#include <stdio.h> #define N 4 int main() { int a[N]={2,0,2,3}; char b[N]={'2','0','2','3'}; int i; printf("sozeof(int)=%d\n",sizeof(int)); printf("sizeof(char)=%d\n",sizeof(char)); printf("\n"); for(i=0;i<N;i++) printf("%p:%d\n",&a[i],a[i]); printf("\n"); for(i=0;i<N;i++) printf("%p:%c\n",&b[i],b[i]); printf("\n"); printf("%p\t%p\n",a,&a[0]); printf("%p\t%p\n",b,&b[0]); return 0; }
1.int型数组在内存中是连续存放的,每个元素占4个字节
2.char型在内存中是连续存放的,每个元素占1个字节
3.一样。

#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; for(i=0;i<N;i++) for(j=0;j<M;j++) printf("%p: %d\n",&a[i][j],a[i][j]); printf("\n"); printf("a=%p\n",a); printf("a[0]=%p\n",a[0]); printf("a[1]=%p\n",a[1]); printf("\n"); for(i=0;i<N;i++) for(j=0;j<M;j++) printf("%p: %c\n",&b[i][j],b[i][j]); printf("\n"); printf("b=%p\n",b); printf("b[0]=%p\n",b[0]); printf("b[1]=%p\n",b[1]); printf("b[0]+1=%p\n",&b[0]+1); printf("b[1]+1=%p\n",&b[1]+1); printf("b[0]+1=%p\n",b[0]+1); printf("b[1]+1=%p\n",b[1]+1); return 0; }
1.是连续存放的,每一个元素占4个字节
2.是一样的
3.是连续存放的,占一个字节
4.是一样的
5.a[0]和a[1]差12个字节,因为每行有三个元素,所以是3*sizeof(int),b[1]和b[0]差3个字节·,对应3*sizeof(char)

#include <stdio.h> #include <string.h> #define N 80 void swap(char si[],char s2[]); void test1(); void test2(); int main() { printf("test1:用两个一维数组,实现两个字符串交换\n"); test1(); printf("test2:用一个二维数组实现两个字符串交换\n"); test2(); return 0; } void swap(char s1[],char s2[]) { char t[N]; strcpy(t,s1); strcpy(s1,s2); strcpy(s2,t); } void test1() { char views1[N]="hey,C,I hate u."; char views2[N]="hey,C,I love u."; printf("交换前:\n"); puts(views1); puts(views2); swap(views1,views2); printf("交换后:\n"); puts(views1); puts(views2); } void test2() { char views[2][N]={"hey,C,I hate u.","hey,C I love u"}; printf("交换前:\n"); puts(views[0]); puts(views[1]); swap(views[0],views[1]); printf("交换后:\n"); puts(views[0]); puts(views[1]); }
因为一维数组数组名和二维数组加一个[]均代表起始元素地址,所以都能实现交换

#include <stdio.h> #include <stdlib.h> #define N 80 int count(char x[]); int main() { char words[N+1]; int n; while(gets(words)!=NULL) { n=count(words); printf("单词数:%d\n",n); } return 0; } int count(char x[]) { int word_flag=0,i,number=0; for(i=0;x[i]!='\0';i++) { if(x[i]==' ') word_flag=0; else if(word_flag==0) { word_flag=1; number++; } } return number; }
优化:把各种标点符号转换成空格符号。

#include <stdio.h> #define N 80 int main() { char line[N]; int word_len; int max=0; int end; int i=0; while(gets(line)!=NULL) { word_len=0; max=0; end=0; i=0; while(1) { while(line[i]==' ') { word_len=0; i++; } while(line[i]!='\0'&&line[i]!=' ') { word_len++; i++; } if(max<word_len) { max=word_len; end=i; } if(line[i]=='\0') break; } printf("最长单词:"); for(i=end-max;i<end;i++) printf("%c",line[i]); printf("\n\n"); } }

#include <stdio.h> #define N 5 void input(int x[],int n); void output(int x[],int n); double avg(int x[],int n); void bubble_sort(int x[],int n); int main() { int scores[N],i; double ave; printf("录入%d个分数:\n",N); input(scores,N); printf("\n输出课程分数:\n"); output(scores,N); ave=avg(scores,N); bubble_sort(scores,N); printf("输出课程平均分:%.2f",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\t",x[i]); printf("\n\n"); } double avg(int x[],int n) { int i,ave=0; for(i=0;i<n;i++) ave+=x[i]; return 1.0*ave/n; } void bubble_sort(int x[],int n) { int i,j,t; for(i=0;i<n-1;i++) for(j=0;j<n-1-i;j++) { if(x[j]<x[j+1]) { t=x[j]; x[j]=x[j+1]; x[j+1]=t; } } }

#include <stdio.h> #define N 100 void dec2n(int x,int n); int main() { int n; printf("输入一个十进制整数:"); while(scanf("%d",&n)!=EOF) { dec2n(n,2); dec2n(n,8); dec2n(n,16); printf("\n输入一个十进制整数:"); } return 0; } void dec2n(int x,int n) { char num1[N]; char str[N]="0123456789ABCDEF"; int i=0,j,t; while(x!=0) { t=x%n; x=x/n; num1[i]=str[t]; i++; } j=i; for(i=j-1;i>=0;i--) printf("%c",num1[i]); printf("\n"); }

#include <stdio.h> #define N 100 #define M 4 void output(int x[][N], int n); // 函数声明 void rotate_to_right(int x[][N], int n); // 函数声明 int main() { int t[][N] = {{199, 120, 67, 844}, {25, 16, 47, 38}, {239, 11, 32, 594}, {42, 261, 33, 10}}; printf("原始矩阵:\n"); output(t, M); // 函数调用 rotate_to_right(t, M); // 函数调用 printf("变换后矩阵:\n"); output(t, M); // 函数调用 return 0; } // 函数定义 // 功能: 输出一个n*n的矩阵x void output(int x[][N], int n) { int i, j; for (i = 0; i < n; ++i) { for (j = 0; j < n; ++j) printf("%4d", x[i][j]); printf("\n"); } } void rotate_to_right(int x[][N],int n) { int i,j,t; for(i=0;i<n;i++) { t=x[i][n-1]; for(j=n-1;j>0;j--) { x[i][j]=x[i][j-1]; } x[i][0]=t; } }

#include <stdio.h> #define N 80 void replace(char x[],char old_char,char new_char); int main() { char x[]="C Programming is difficult or not,it is a question."; printf("原始文本:\n"); printf("%s",x); replace(x,'i','~'); printf("处理后文本:\n"); printf("%s",x); return 0; } void replace(char x[],char old_char,char new_char) { int i; for(i=0;x[i]!='\0';i++) if(x[i]==old_char) x[i]=new_char; }

#include <stdio.h> #define N 80 int main() { char str[N],ch; int i=0; printf("输入字符串:"); gets(str); printf("\n输入一个字符:"); ch=getchar(); printf("截断处理......\n"); while(str[i]!='\0') { if(str[i]==ch) { str[i]='\0'; break; } i++; } str[i]='\0'; printf("截断处理后字符串:"); printf("%s",str); return 0; }

#include <stdio.h> #include <string.h> #define N 5 #define M 20 void bubble_sort(char x[][M],int n); int main() { char name[N][M]={"Bob","Bill","Joseph","Taylor","George"}; int i; for(i=0;i<N;i++) printf("%s\n",name[i]); bubble_sort(name,N); printf("\n排序中...\n"); for(i=0;i<N;i++) printf("%s\n",name[i]); return 0; } void bubble_sort(char x[][M],int n) { int i,j; char t[M]; for(i=0;i<n-1;i++) for(j=0;j<n-i-1;j++) { if(strcmp(x[j],x[j+1])>0) { strcpy(t,x[j]); strcpy(x[j],x[j+1]); strcpy(x[j+1],t); } } }


浙公网安备 33010602011771号