金山WPS暑期实习招聘笔试题2013-7-28

原创 2013年10月01日 20:00:25

C++试卷B

 

应聘职位1.                        2.                     

姓    名:               性    别:      学    位:                

所在院校:              所学专业:                      

联系电话:                   电子邮件:                           

毕业时间:               获知招聘信息渠道:                              

说明:

答题时间为 100 分钟

自我判断题(请选择最符合您本人意愿的一项)

1、你觉得你的能力特点是:( d  )

a. 注重团队交流

b. 注重细节、追求完美

c. 擅长钻研

d. 重视知识积累

e. 做事仔细,思维慎密

2、你觉得你的思维特点:( c  )

a. 创造力

b. 想象力

c. 把握复杂问题

d. 洞察细节

3、你最喜欢的做事方式:(  a )

a. 用妥当的方式处理问题

b. 用快速的方式处理问题

c. 用直观的方式处理问题

4、对你的合作伙伴你最不能接受的缺点是:( b  )

a. 浮夸

b. 粗心大意

c. 墨守成规

d. 不求上进


选择题(单项选择)

 

1int x = 18 / 7 * 3;

   x变量的数值为:( a  

a. 6        b. 7       c. 8        d. 9

 

2c++是否是大小写敏感的:( a  

a.        b. 不是

 

3以下程序的输出结果是:(  

std::cout << "0" << std::endl;

a. 0    b. "0"     c. 48

 

4、以下哪个不是c++关键字:( d  )

a. class    b. int     c. struct     d. printf

 

5int * p = new int[10];

和上述语句匹配的释放语句是:( c  

a. free(p)        b. delete p;         c. delete [] p;        d. delete p [];

 

6int * p = new int;

以下那行语句是合法的:( a  

a. *p = 3;     b. p = *3;     c. &p = 3;     d. p = &3;

 

7const int x = 0x20;

printf("%d", x);

以上代码片段的输出是:(  

a. 20        b. %d          c. 32

 

8char x[] = "hello"

sizeof(x)的结果为:c

a. 4    b. 5    c. 6

 

9printf("5432" + 1);

上述代码的输出结果是:( a  

a. 432        b. 5433       c. 54321       d. 编译不通过

 

10std::vector<T> x;

x.resize(10);

sizeof(x)的结果为:( 

a. 0       b. 4       c. 10       d. 不确定

 

综合题

1、请实现这么一个函数:传入一个int值,在屏幕输出类似LED显示屏效果的字母拼图,例如:

输入1234567890,输出:

 

提示:请注意每个字符的固定宽度和高度,两个数字间保留一个空格。

函数签名:void LEDprint(int num);

#define HEIGHT 7

void LEDprint(int num)

{

   int a[14];

   int i=0;

   while(num)

   {

      a[i]=num%10;

      i++;

      num/=10;

}

for(int j=0;j<HEIGHT;j++)

{

  for(int k=i-1;k>=0;k--)

{

    static int m=0;

    switch(a[k])

    {

       case 0:

       switch(j)

       {

           case 0:

           case 6:

              printf(“---”);

              break;

           case 1:

           case 2:

           case 3:

           case 4:

           case 5:

              printf(“|   |”);

         break;

}

break;

case 1:

  switch(j)

{

   case 0:

   case 6:

   printf(“   ”);

   break;

   case 1:

   case 2:

  case  3:

   case 4:

   case 5:

   printf(“  |”);

  break;

}

break;

       case 2:

         switch(j)

         {

              case 0:

              case 3:

              case 6:

              printf(“---”);

              break;

              case 1:

              case 2:

              printf(“  |”);

              break;

              default:

              printf(“|  ”);

}

break;

       case 3:

         switch(j)

         {

             case 0:

             case 3:

             case 6:

              printf(“---”);

             break;

          default:

             printf(“  |”);

           break;

}

 break;

       case 4:

        switch(j)

        {

            case 0:

               printf(“   ”);

               break;

            case 1:

            case 2:

               printf(“|  |”);

               break;

            case 3:

               printf(“---|”);

               break;

            default:

               printf(“  |”);

             break;

}

  break;

case 5:

  switch(j)

  {

             case 0:

             case 3:

             case 6:

              printf(“---”);

             break;

             case 1:

             case 2:

               printf(“|   ”);

              break;

             default:

              printf(“   |”);

             break;

}

break;

       case 6:

         switch(j)

         {

        case 0:

        case 6:

            printf(“---”);

            break;

        case 1:

        case 2:

            printf(“|   ”);

            break;

        case 3:

            printf(“|---”);

            break;

        default:

           printf(“   |”);

}

 break;

case 7:

 switch(j)

 {

     case 0:

        printf(“---”);

        break;

     default:

       printf(“   |”);

}

  break;

case 8:

 switch(j)

{

  case 0:

   case 6:

    printf(“---”);

    break;

   case 3:

    printf(“|--|”);

    break;

 default:

   printf(“|  |”);

   break; 

}

  break;

case 9:

 switch(j)

 {

   case 0:

   case 6:

       printf(“---”);

       break;

   case 3:

      printf(“--|”);

      break;

  case 1:

  case 2:

      printf(“|  |”);

      break;

 default:

      printf(“   |”);

      break;

}

  break;

}

}

   m++;

   if(m==2)

   {

       printf(“ ”);

       m=0;

}

printf(“\n”);

}

 

 

2、请编写一段代码测试以下函数执行的正确性:

void unique(std::vector<int> & v);

这个函数的职责是去除传入数组中的重复元素。

提示1:函数返回结果不一定是依照某种顺序的;

提示2:请尽可能多的考虑各种可能出现bug的情况组合;

提示3:你编写的代码应当返回一个int值,返回0表示测试通过,返回1表示出现错误

int com(const void* a,const void* b)

{

   return (*int*)a-*(int*)b;

}

int test(std::vector<int> &v)

{

unique(v);

qosrt(v.begin(),v.size(),sizeof(int),com);

for(int i=0;i<v.size()-1;i++)

    if(v[i]==v[i+1])

       return 0;

return 1;

}

 

 

3、实现如下函数:

void printInChinese(int num);

这个函数输入一个小于100000000(一亿)的正整数,并在屏幕上打印这个数字的中文写法。

例如:

17 -> 一十七

120 -> 一百二十

201 -> 二百零一

1074 -> 一千零七十四

65536 -> 六万五千五百三十六

1010101 -> 一百零一万零一百零一

提示:请注意‘零’的处理。

扩展:如果需要处理通用简化习惯,你将怎么处理,例如:

17 -> 十七

120 -> 一百二

void printInChinese(int num)

{

char* wei[]={“”,”十”,”百”,”千”,”万”,”十”,”百”,”千”};

char* num1[]={“零”,”一”,”二”,”三”,”四”,”五”,”六”,”七”,”八”,”九”};

int a[9];

int i=0;

int tmp,flag=0;

while(num)

{

    a[i]=num%10;

    num/=10;

    i++;

}

for(int j=i-1;j>=0;j--)

{

   if(a[j]==0)

     if(flag==0)

   {

      flag=1;

      tmp=j;

}

else

{

   if(flag==1)

   {

      if(tmp-j>=4)   //中间零数超过四位

         printf(“万”);

       printf(“零”);

      flag=0;

      tmp=0;

}

printf(“%s%s” ,num1[a[j]], wei[j]);

}

}

}

//对于特殊情况的考虑 需要考虑在十位和十万位开头 且为1的情况。

末尾的情况稍微复杂点 可以考虑先将所有要输出的数据缓存,然后根据末尾0的情况适当输出。
已知完全弹性碰撞公式如下:

其中m1 m2为小球质量,v1 v2为原始速度,v1' v2'是碰撞后的速度。

struct ball_t {

double m; // 质量

double v; // 速度,速度为正表示球体往x轴正方向运动

double pos; // x坐标轴的位置

};

请实现以下函数:

void progress(ball_t & b1, ball_t & b2, double leftWall, double rightWall, double t);

这个函数输入两个球的当前状况(包括质量,速度,在x轴的位置),以及左右墙壁的位置,输出两个球在t秒钟后的状况(包括质量,速度,在x轴的位置)。

特殊说明:球体碰撞墙面也是完全弹性碰撞,即球体速度变为原本的负数。

 

 

 

 

4、一个工程由如下文件组成:

head1.h head2.h src1.cpp src2.cpp main.cpp

最终编译结果为xxx.exe(或者xxx,如果在linux下的话)

请写出你熟悉的某种编译器将这5个文件转换为最终结果xxx.exe(或xxx)的详细过程。写出每一个步骤,并作相关的解释,如果你熟悉某编译器的话,请写出这个编译器每一步用到的命令行。

 

先将head1.hsrc1.cpp文件生成1.o文件

head2.hsrc2.cpp文件生成2.o文件

再将main.cpp文件生成main.o文件

最后将这些.o文件生成xxx.exe

 

g++ -o 1.o  head1.h src1.cpp

g++ -o 2.o  head2.h src2.cpp

g++ -o main.o main.cpp

g++ -o xxx.exe main.o 1.o 2.o

 

2016金山WPS春季实习招聘笔试&面试问题回忆

下面将我在广州参加的2016年春季金山WPS实习招聘的整个过程中遇到的问题记录如下。不全,但是有些题目还是值得思考的。1.笔试题2016.4.11晚上在中山大学东校区(大学城校区)参加了金山WPS的笔...
  • K346K346
  • K346K346
  • 2016年04月17日 18:15
  • 7259

金山wps2017校招笔试(前端A卷)

昨天有幸参加金山wps校招笔试(前端岗A卷),虽然题目不多,难度不大,但是还是感觉没有发挥好,所以将相关的题目的贴出来,以备往后学习之用。 1. 以下代码A、B、C处分别输出什么(答案已在注...
  • zhangwx6
  • zhangwx6
  • 2017年04月15日 23:01
  • 1223

金山WPS笔试题

#include #include int fun(unsigned int v){     unsigned int t=v;     while(t!=0)     {    ...
  • ai309581115
  • ai309581115
  • 2014年10月28日 10:31
  • 697

WPS面试经历

在连续跪了三次笔试后,终于
  • a549875231
  • a549875231
  • 2014年04月25日 17:05
  • 1881

2015:WPS笔试-Android开发岗位

题目一共三道: 一:实现一个函数,可以判断两条直线的关系:平行、重合、垂直或相交。 二:实现一个函数,可以得到任意两个日期的相隔天数。 三:针对题目一或题目二,实现一个完整的单元测试。...
  • u013670933
  • u013670933
  • 2015年04月01日 02:29
  • 1031

【直播】西山居2014校园招聘策划类笔试试题

转自百度贴吧剑三吧:http://tieba.baidu.com/p/2591476441?see_lz=1 首先描述你会使用的技能  写出下列游戏的厂商 游戏类型 操...
  • qqagsd155451
  • qqagsd155451
  • 2016年11月27日 23:26
  • 1205

2018年金山WPSweb前端开发试题

1. 列出http协议头部信息并简述其作用。http://www.cnblogs.com/9988/archive/2012/03/21/2409086.html2. 浏览器如何请求并渲染页面的。ht...
  • hu_lanlan
  • hu_lanlan
  • 2017年09月15日 14:56
  • 631

2012-9-26 金山WPS笔试题

今晚的笔试题目不难,所考算法也不是很难,关键在仔细审题和平常的积累…… 1. 有770个节点的完全二叉树,问叶子节点有多少?(重点是叶子节点,不是最下一层的节点数目,陷阱呀) 可以计算得出该完全二...
  • shenshuiyoulan
  • shenshuiyoulan
  • 2012年09月26日 22:42
  • 3807

金山的笔试题总结

一、var arr = []; arr['a'] = 1; console.log(arr.length); // 0 arr['2'] = 2; console.log(arr.length); /...
  • shuidinaozhongyan
  • shuidinaozhongyan
  • 2017年09月12日 14:38
  • 268

金山面试题目(c++经典收藏1)

笔试题目(C++) 1. sizeof用法,和strlen的区别 2. 各种数据结构,如堆、栈、队列等的特征和作用 3. 什么是野指针,什么情况下会产生野指针,如何避免? 4.快速排序的时间复...
  • ghevinn
  • ghevinn
  • 2012年08月24日 15:53
  • 1187
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:金山WPS暑期实习招聘笔试题2013-7-28
举报原因:
原因补充:

(最多只允许输入30个字)