小示例题

完成下面的方法,要求返回一个验证码,并且不能同时存在容易混淆的0和Q。每个字母取得的概率要相同。

  他先给出了一部分代码:

 //生成一个随机验证码并且0和O不能同时出现
        public string CreateCode(int count)
        {
           //验证码字符串
            string strcode = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z";
            string[] codes = strcode.Split(',');
            //验证码为空
            string validatecode = string.Empty;
            //实例化随机类
            Random rand=new Random();
            do
            {
                validatecode = string.Empty;
                for (int i = 0; i < count; i++)
                {
                    string s = codes[rand.Next(0, 35)];
                    validatecode += s;
                }
            } while (validatecode.Contains('0') && validatecode.Contains('O'));
               return validatecode;
           
        }

一个选择题,写了一个类:

复制代码
  public class ClassA
    {
        public static int Count = 0;
         static ClassA()
        {
            Count++;
        }

        public ClassA()
        {
            Count++;
        }
    }
复制代码

然后求下面代码的输出结果:

 ClassA A1 = new ClassA();
            ClassA A2
= new ClassA();
            Console.WriteLine(ClassA.Count);

因为静态构造函数是属于类的,而不属于任何一个实例,所以这个构造函数只会被执行一次,而且是在创建此类的第一个实例或引用任何静态成员之前,由.NET自动调用。所以结果为:3

3 也是一个选择题。主要是考override与new的区别,题目大概如下

abstract public class BaseClass
    {
       
public virtual void print()
        {
            Console.WriteLine(
"From BaseClass");
        }

    }

   
public class class1 : BaseClass
    {
       
public override void print()
        {
            Console.WriteLine(
"From Class1");
        }
    }

   
public class class2 : BaseClass
    {
       
public new void print()
        {
            Console.WriteLine(
"From Class2");
        }
    }

然后求执行下面代码后的输出结果:

 

BaseClass ct2 = new class2();
            ct2.print();

 

答案会是:From BaseClass.因为new关键字只是隐藏了Class2中BaseClass的print()方法,并没有改变BaseClass中的Print()方法。

 

而BaseClass ct2 = new class2() 实例化的是BaseClass.

 

但如果调用的是:

ClassA A1 = new ClassA();
            ct1.print();

输出会是:From Class1。因为override关键字在Class1中将BaseClass中的Print()方法进行了重写

 

4 数据库题目。用一个update方法更新两个条件不同的记录。大意是这样的:修改Product表,将Price大于1000的产品的Price提高5%,将Price小于1000的产品的Price提高10%,要求只用一个update。

 

想到用case..when语句

update Product set UnitPrice=(case when (UnitPrice>1000) then UnitPrice*1.05 when (UnitPrice<1000) then UnitPrice*1.1 else UnitPrice end)

 

 5.实例化ClassB后输出结果

class ClassA
    {
       
public ClassA()
        {
            Print();
        }

       
public virtual void Print()
        {
        }
    }

   
class ClassB : ClassA
    {
       
int a = 1;
       
int b;
       
public ClassB()
        {
            b
= -1;
            Print();
        }

       
public override void Print()
        {
            Console.WriteLine(
"a="+a+"  b="+b);
        }
    }

结果:a=1,b=0   a=1,b=-1

6.sql删除除主键外的重复数据

  delete from StuInfo where ID not in(select MIN(id) from StuInfo group by Name,Dept,StuNo,Sex)

   用Max或Min函数都行

7.

找出所有科目的成绩都大于80的学生姓名。

思路1:所有大于80分就是名字不在小于80分的学生里面的学生,主要是用到了一个逆向思维

select distinct Name from Student where Name not in(select Name from Student where Score<80)

思路2:所有大于80分即该学生的最小成绩也大于80.

select name,MIN(Score) from Student group by Name having MIN(Score)>80

思路3:所有大于80分则要求该学生大于80分的科目要有3个(即科目数)。

 select Name,COUNT(*) from Student where Score>80 group by Name having COUNT(*)=3

8.将1-100插入到一个长度为100的数组中

 public void Print()
        {  
            int[] array = new int[100];
            Random rand = new Random();
            int newnum;
            for (int i = 0; i <array.Length; i++)
            {
                do
                {
                    newnum=rand.Next(101);
                  
                }while(array.Contains(newnum));//数组是否存在该值
                array[i]=newnum;
            }
            //按升序排序
            int temp;
            for(int j=0;j<array.Length-1;j++)
            {
                for (int k = array.Length-1; k > j; k--)
                {
                    if (array[k - 1] > array[k])
                    {
                        temp = array[k - 1];
                        array[k - 1] = array[k];
                        array[k] = temp;
                    }
               
                }
            }
            //打印输出
            for (int n = 0; n < array.Length; n++)
            {
                Console.WriteLine(array[n]);
            }
        }

9.求数列:1、1、2、3、5、8、13、21...的第N个数是多少

         /// <summary>
        /// 斐波那契数列
       
/// </summary>
        /// <param name="i"></param>
        /// <returns></returns>
        private static int Fibonacci(int i)
        {
           
if (i <=2)
            {
               
return 1;
            }
           
else
            {
               
return Fibonacci(i - 1) + Fibonacci(i - 2);
            }
        }

10.统计某个字符串在文本中出现的次数。

 

  public int Count(string text,string find)
        {
            int count = 0;//出现的次数
            int position = 0;//位置
            int index = 0;//索引位置
            do
            {
                index = text.IndexOf(find,position);
                if (index > 0)
                {
                    count++;
                    position=index+1;
                }
            } while (index > 0);

 

            return count;
        }

 

 

 

posted @ 2012-06-18 22:40  zhangchun  阅读(361)  评论(0编辑  收藏  举报