2012搜狗校园招聘笔试题

1. 选出程序输出的结果
#include <iostream>

using namespace  std;

int main()

{
    short input[10]={'A','B','C','D','E'};
    unsigned char *p=(unsigned char*)&input;
    int s=0;
    int temp=sizeof(input);
    for(int i=0; i<temp; ++i)
    {
        char v=p[i];
        if(v>0)
        s+=v-'A'+i;
    }
    printf("%d\n",s);
}

答案 :A:10    B:15    C:25  D:30  E:35  F:得到不确定的结果或程序崩溃

这个题目要考虑大小端存储,因为x86平台下是小端模式所以对于input而言,内存如下:A0B0C0D0E0 0000000000当强制将内存按照char的方式读取的时候,i 分别在0 2 4 6 8 的位置是 非零,然后加上各自对应的值0 1 2 3 4 所以最后结果是 20 + 10 = 30对于在大端模式的平台下:0A0B0C0D0E 0000000000这样组后的结果就是 1 3 5 7 90 1 2 3 4是 25 + 10 = 35但是题目没有给出是大端还是小端模式,所以选F2. 写出程序的输出
char *c[] = { "ENTER", "NEW", "POINT", "FIRST" };
char **cp[] = { c+3, c+2, c+1, c };
char ***cpp = cp;


int main(void)
{
 printf("%s", **++cpp);
 printf("%s", *--*++cpp+3);
 printf("%s", *cpp[-2]+3);
 printf("%s\n", cpp[-1][-1]+1);
 return 0;
}
指针比较繁琐,仔细点应该不会有问题,分析如下:第一个输出如下:

2012搜狗校园招聘笔试题

第二个输出如下:

2012搜狗校园招聘笔试题

第三个输出如下:

2012搜狗校园招聘笔试题

第四个输出如下:

2012搜狗校园招聘笔试题

最后结果:Pointerstew

linux

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/20797.html