Fork me on GitHub

公司笔试题

    去年2月份的时候刚来深圳,在第一家公司面试,也是我现在所在的公司.当时主管给我做了一套笔试题,结果不是很理想,当时我还特意写了篇博文:求职路 第二章 技术篇

被录用之后,我找主管要了一份当时的笔试题,又重新做了次.昨天偶然发现了这张试题,算是对自己的一个回顾.

   主要是2道算法题和1道sql题,当时确实很菜,算法题有错误,而sql全挂,也感谢老大把这么菜的我招到麾下,让我磨练至今.当然现在我的sql依然很菜,确实不太有兴趣研究数据库.

算法题1:以C#或JavaScript语言实现一个斗地主的发牌算法.(都地主发牌规则:共54张牌,3人打,没人发17张,剩余3张.)

PS:其实我以前没玩过斗地主,后来才知道怎么玩.当然还是不怎么喜欢玩:)

我理解这个题,就是把54张牌先预制好,然后打乱顺序,依次发给3个玩家.最核心的应该是洗牌的算法.我的思路是:

1.生成一个长度为54的数组.为数组赋上初值1~54.

2.在1~54中生成一个随机数.

3.把这个数的位置与数组最后一位交换.

4.依次递减数组长度.直到长度为0.

 static void Shuffle(int[] cards)
    {
        int length = cards.Length-1;
        int index = length;
        Random r = new Random();
        while(index>0)       
        {
            int rand = r.Next(index);
            int tmp = 0;
            tmp = cards[rand];
            cards[rand] = cards[index];
            cards[index] = tmp;
            index--;
        }
    }

发牌时初始化1个2维数组,行列分别为4,17.然后依次发牌,知道剩余3张放入数组.

完整代码如下:

using System;
 
class ctest
{
    static void Main()
    {
        int[] cards = new int[54];
        int[,] persons = new int[4,17];//3人和剩余;
        for(int i = 0;i<cards.Length;i++)
            cards[i] = i+1;
        Shuffle(cards);
        DealCards(persons,cards);
        //print(cards);
        print(persons);
    }
 
    static void DealCards(int[,] persons,int[] cards){   
        // persons[4,0] = cards[0];
        // persons[4,1] = cards[1];
        // persons[4,2] = cards[2];
        // int count = 3;
        // while(count<cards.Length){
            // int index = count % 3;           
            // persons[index,cards.Length/3]=cards[count];
            // count++;
        // }       
        int count=0;
        for(int i = 0;i< 3 ;i++){
            for(int j = 0;j<17;j++){
                persons[i,j] = cards[count++];
            }
        }
        for(int i=0;count<cards.Length;i++)
            persons[3,i] = cards[count++];
    }
 
    static void Shuffle(int[] cards)
    {
        int length = cards.Length-1;
        int index = length;
        Random r = new Random();
        while(index>0)       
        {
            int rand = r.Next(index);
            int tmp = 0;
            tmp = cards[rand];
            cards[rand] = cards[index];
            cards[index] = tmp;
            index--;
        }
    }
 
    static void print(int[] mat)
    {
        for(int i = 0;i<mat.Length;i++)
            Console.Write(mat[i]+" ");
        Console.WriteLine();
    }
 
    static void print(int[,] persons)
    {
        for(int i = 0;i < 4; i++)
        {
            for(int j = 0;j<17;j++)
                Console.Write(persons[i,j]+" ");
            Console.WriteLine();
        }
    }
 
}

 

算法题2:以C#或JavaScript语言实现方法,计算参数(m)的表达式1+2-3+4-5...m的值.

这个题其实很简单,就是偶数符号的变化.

class test
{
static void Main()
{
    Console.WriteLine(CalculateSum(6));
    Console.Read();
}
 
static int CalculateSum(int m)
{
    int sum = 1;
     for(int i = 2 ; i <= m; i++)
     {
        if(i%2==0)
            sum+=i;
        else
            sum-=i;
     }
     return sum;
}
}

 

数据库题:SqlServer2005,表DataTable

id  value
1 1
2 1
5 2
6 2
8 3
9 3

 

1.将左表中的数据,按id排序,每两行一组求value的和,生成一张新的视图.

2.按id排序,取得所有的奇数(单数)行value之和.

3.取得所有id为奇数的行value之和.

从题目可以看出难度依次降低.

首先建表:

CREATE TABLE [dbo].[DataTable](
[Id] [int] NULL,
[Value] [int] NULL
) ON [PRIMARY]

 

3.SELECT SUM(Value) SumValue FROM DataTable dt WHERE id%2=1

2.SELECT SUM(m.value) SumValue FROM (

SELECT ROW_NUMBER() OVER(ORDER BY id) row,id, VALUE FROM
DataTable dt) m WHERE m.row%2=1

1.只能想到这种取出值插入表的方式,使用rownum也好,使用游标也好.

CREATE TABLE #temp(SumValue INT)
DECLARE @count INT,
@index INT = 1,
@l INT = 1,
@value INT
SELECT @count=COUNT(*) FROM DataTable dt
WHILE(@index<=@count)
BEGIN
SELECT @value = SUM(dt.VALUE) FROM (
SELECT ROW_NUMBER() OVER(ORDER BY id) row,id, VALUE FROM
DataTable) dt WHERE dt.row BETWEEN @l AND @l+1
INSERT INTO #temp(SumValue)VALUES(@value)
set @index=@index*2
SET @l=@index+1
END
SELECT * FROM #temp t

 

小公司,简单的题目.这应该算泄题了:)

posted @ 2013-11-10 19:22  idoku  阅读(659)  评论(1编辑  收藏  举报