一、判斷題(對的寫T,錯的寫F并說明原因,每小題4分,共20分) 1、有數(shù)組定義int a[2][2]={{1},{2,3}};則a[0][1]的值為0。( T ) 2、int (*ptr) (),則ptr是一維數(shù)組的名字。( F ) ptr是函數(shù)指針 3、指針在任何情況下都可進行>,<,>=,<=,==運算。( T ) 雖然安全性有問題, 4、switch(c) 語句中c可以是int ,long,char ,float ,unsigned int 類型。( F ) float不行。 5、#define print(x) printf("the no , " #x ", is ") ( T )自己運行一遍通過。 二、填空題(共30分) 1、在windows下,寫出運行結果,每空2分,共10分。 char str[ ]= "Hello"; char *p=str; int n=10; sizeof(str)=( 6 ) sizeof(p)=( 4 ) sizeof(n)=( 4 ) void func(char str[100]) { } sizeof(str)=( 4 ) 2、void setmemory(char **p, int num) { *p=(char *) malloc(num);} void test(void) { char *str=NULL; setmemory(&str,100); strcpy(str,"hello"); printf(str); } 運行test函數(shù)有什么結果?( hello )10分 3、設int arr[]={6,7,8,9,10}; int *ptr=arr; *(ptr++)+=123; printf("%d,%d",*ptr,*(++ptr)); ( 8,8 ) 10分 二、編程題(第一小題20,第二小題30分) 1、 不使用庫函數(shù),編寫函數(shù)int strcmp(char *source, char *dest) 相等返回0,不等返回-1;
int strcmp_my(char *source, char *dest)
{ while(*source++==*dest++) { if(*--source==‘\0‘) return 0; *source++; } return -1; } 2、 寫一函數(shù)int fun(char *p)判斷一字符串是否為回文,是返回1,不是返回0,出錯返回-1
int fun(char *p)
{ if((p==NULL)||(*p==‘\0‘)) return -1; int length=strlen(p); char *p2=p+length-1; while(*p++==*p2--) { if(p>=p2) return 1; } return 0; } |
|