[转载]2005华为C语言笔试题

一、判断题(对的写T,错的写F并说明原因,每小题4分,共20分)

1、有数组定义int a[2][2]={{1},{2,3}};则a[0][1]的值为0。( T )

2、int (*ptr) (),则ptr是一维数组的名字。( F, ptr为一个函数指针 )

3、指针在任何情况下都可进行>,<,>=,<=,==运算。( F,指针比较大小没有任何意义,但是可以比较==与!= )

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函数有什么结果?( 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、不使用库函数,编写函数int strcmp(char *source, char *dest) 相等返回0,不等返回-1;

int mystrcmp(char *source, char *dest)
{
        while(*source == *dest && *source != '/0' && *dest != '/0')
        {
              source++;
              dest++;
        }
        if (*source =='/0' && *dest == '/0')
              return 0;
       else
              return -1;
}


        2、写一函数int fun(char *p)判断一字符串是否为回文,是返回1,不是返回0,出错返回-1
int rollback(char *str){
               char *p;
       int i = 0;
               if(str == NULL)
                     return -1;
                     p = str;

               while(*str) {
                     i++;
                    str++;
               } ;
               str--;

               while(i>0 && *p == *str) {
                     *p++;
                     *str--;
                     i-=2;
               }

               if (i<=0)
             return 1;
       else
             return 0;
       }


3.请问C++的类和C里面的struct有什么区别?
答:struct的成员的默认访问说明符为Public,而class的成员的默认访问说明符为Private。其他没有区别


4.请讲一讲析构函数和虚函数的用法和作用。
答:析构函数是在对象生存期结束时自动调用的函数,用来释放在构造函数分配的内存。
虚函数是指被关键字virtual说明的函数,作用是使用C++语言的多态特性。


5.全局变量和局部变量有什么区别?是怎么实现的?操作系统和编译器是怎么知道的?
答:一些变量在整个程序中都是可见的,它们称为全局变量。一些变量只能在一个函数中可知,称为局部变量。这就是他们的区别。
在任何函数外面定义的变量就是全局变量,在函数内部定义的变量是局部变量,这是它们在程序中的实现过程。
操作系统和编译器是根据程序运行的内存区域知道他们的,程序的全局数据放在所分配内存的全局数据区,程序的局部数据放在栈区。


6。有1,2,3,4,,,,n个数放在一个数组里,按大小排序,输出。(简单排序算法)
        #include <stdio.h>
        #define SWAP(a,b) {a+=b;b=a-b;a-=b;}

        void mybubble(int array[], int len) {
               int i=0, j=len-1, flag;

               for(j=len-1;j>0;j--) {
                     flag=0;
                     for(;i<j;i++) {
                           if(array[i]<array[i+1]) {
                                SWAP(array[i],array[i+1]);
                                 flag=1;
                           }  
                     }
                     if(flag == 1)
                        break;
               }
         }

          void main(){
                 int i;
                 int testarray[10]={0,3,5,1,7,2,6,9,4,8};
                 mybubble(testarray,10);
                 for(i=0;i<10;i++) {
                       printf("%d/n",testarray[i]);
                 }
           }


7。写一个算法,将一个数按高位到低位逆转,例如,用户输入123,则输出321。

        #include <stdio.h>

        int myinvert(int a) {
              int b=0;

              while(a>0) {
                     b = (10*b) + (a%10);
                     a /= 10;
              }
 
              return b;
        }

        void main(){
               int test=9836, result;
               result = myinvert(test);
               printf("%d/n",result);
        }

        8。抽象类和接口的区别是什么?
(1)接口可以被多重implements,抽象类只能被单一extends
(2)接口只有定义,抽象类可以有定义和实现
(3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly" 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值