关于2017年软通动力校招的笔试题

1.输入一个数组,按照英文26个字母顺序,输出每个数字对应的字母,如果查找不到,则输出? 如[1, 3, 30], 输出ac?。

用java编译:

public class Zs {


/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
        int arr[]={1,3,30};
       for(int i=0;i<arr.length;i++)
        {
        if(1<=arr[i]&&arr[i]<=26)
        {
        System.out.println((char)('a'+arr[i]-1));
        }
        else
        System.out.println('?');
        }
         System.out.println('\n');
}

}

用C编译:

#include<stdio.h>
#include<string.h>
void main()
{
int  array[]={1,3,30};
    for(int i=0;i<sizeof(array)/sizeof(int);i++)
{
if(1<=array[i]&&array[i]<26)
printf("%c",'a'+array[i]-1);
else
printf("%c",'?');
}
printf("\n");
}

在java中将ASCII转换成字符的形式为   

如果是单个字符的话,直接转换就可以

int d=97
char e = (char)d;

如果是一串ascii码的话,最好存在byte[]中

byte[] b ={97, 98, 99};
System.out.println(new String(b));
2.将一个字符串里出现最多的字母截取,如:addcbbs变为acs。

#include<stdio.h>
#include<string.h>
void main()
{
char* str = "addcbbs";
int buf[256] = { 0 };//ASCII码占用一个字节,可以有0~255共256个取值。
char result[256] = { 0 };
int len = strlen(str);
int i = 0;
int max = 0;
int j = 0;
for (i = 0; i < len; i++)
{
buf[str[i]]++;
}
for (i = 0; i < 256; i++)
{
if (buf[i]>max)
max = buf[i];
}
for (i = 0; i < len; i++)
if (buf[str[i]] < max)
result[j++] = str[i];//将小于max的字符放入result数组
printf("source:%s\n", str);
printf("result:%s\n", result);
system("pause");
}

里面的buf[str[i]]++是统计str里面的字符在buf[256]里面出现的次数。

阅读更多
博主设置当前文章不允许评论。

做过的软通动力笔试题

2012年07月13日 37KB 下载

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭