题一:

程序设计: 猫大叫一声,所有的老鼠都开始逃跑,主人被惊醒。(C#语言)
要求:  
            <1>.构造出Cat、Mouse、Master三个类,并能使程序运行
            <2>从Mouse和Master中提取抽象
            <3>联动效应,只要执行Cat.Cryed()就可以使老鼠逃跑,主人惊醒。

using System;
using System.Collections;
using System.Collections.Generic ; namespace gtkTest
{
public class ObserverClass
{
public ObserverClass ()
{ }
public static void ObserverFun ()
{
Cat cat = new Cat();
Mouse mouse1 = new Mouse("mouse1", cat);
Mouse mouse2 = new Mouse("mouse2", cat);
Master master = new Master(cat);
cat.Cry();
}
public interface Observer
{
void Response(); //观察者的响应,如是老鼠见到猫的反映
}
public interface Subject
{
void AimAt(Observer obs); //针对哪些观察者,这里指猫的要扑捉的对象---老鼠
}
public class Mouse : Observer
{
private string name;
public Mouse(string name, Subject subj)
{
this.name = name;
subj.AimAt(this);
} public void Response()
{
Console.WriteLine(name + " attempt to escape!");
}
}
public class Master : Observer
{
public Master(Subject subj)
{
subj.AimAt(this);
} public void Response()
{
Console.WriteLine("Host waken!");
}
} public class Cat : Subject
{
private ArrayList observers;
public Cat()
{
this.observers = new ArrayList();
}
public void AimAt(Observer obs)
{
this.observers.Add(obs);
}
public void Cry()
{
Console.WriteLine("Cat cryed!");
foreach (Observer obs in this.observers)
{
obs.Response();
}
}
} }
} //2 using System; namespace gtkTest
{
public class ObserverDeleClass
{
public ObserverDeleClass ()
{ }
public static void ObserverDeleFun ()
{
Cat cat = new Cat();
Mouse mouse1 = new Mouse("ObserverDelemouse1", cat);
Mouse mouse2 = new Mouse("ObserverDelemouse2", cat);
Master master = new Master(cat);
cat.Cry();
}
//---------------------------------------------------------------------------------------------
//设计方法二: 使用event -- delegate设计..
public delegate void SubEventHandler();
public abstract class Subject
{
public event SubEventHandler SubEvent;
protected void FireAway()
{
if (this.SubEvent != null)
this.SubEvent();
}
}
public class Cat : Subject
{
public void Cry()
{
Console.WriteLine("ObserverDelecat cryed.");
this.FireAway();
}
}
public abstract class Observer
{
public Observer(Subject sub)
{
sub.SubEvent += new SubEventHandler(Response);
}
public abstract void Response();
}
public class Mouse : Observer
{
private string name;
public Mouse(string name, Subject sub) : base(sub)
{
this.name = name;
}
public override void Response()
{
Console.WriteLine(name + " attempt to escape!");
}
}
public class Master : Observer
{
public Master(Subject sub) : base(sub){}
public override void Response()
{
Console.WriteLine("ObserverDelehost waken");
}
} }
}
//3 gtkTest.ObserverDeleClass.ObserverDeleFun(); gtkTest.ObserverClass.ObserverFun ();

  

参考: https://blog.csdn.net/hunterxray/article/details/1532674

题二:


一列数的规则如下: 1、1、2、3、5、8、13、21、34......  求第30位数是多少, 用递归算法实现

public class MainClass
{
public static void Main()
{
Console.WriteLine(Foo(30));
} public static int Foo(int i)
{
if (i <= 0)
return 0;
else if(i > 0 && i <= 2)
return 1;
else return Foo(i -1) + Foo(i - 2);
}
}

参考:https://blog.csdn.net/zhangzuqing/article/details/20208385

题三

using System;

namespace gtkTest
{
public class MyClassv
{
public MyClassv ()
{
v1++;
v2++;
}
public static int v1;
public int v2;
public static void MyClassvFun ()
{
MyClassv mc1 = new MyClassv (), mc2 = new MyClassv ();
Console.WriteLine("{0}{1}{2}",MyClassv.v1,mc1.v2,mc2.v2); }
}
}

  

gtkTest.MyClassv.MyClassvFun ();

  

注意:

题四

  gtkTest.MyStringClass .MyStringClassFun();
gtkTest.MyStringClass .MyIntClassFun();
gtkTest.MyCountClass.MyCountClassFun ();

  

using System;

namespace gtkTest
{
public class MyStringClass
{
public MyStringClass ()
{
}
public static void MyStringClassFun ()
{
string sr1 = "123" + "abc";
string sr2 = "123abc";
Console.WriteLine(sr1==sr2);
Console.WriteLine(System .Object.ReferenceEquals(sr1,sr2 ));
} public static void MyIntClassFun ()
{
int i = 5;
int j = 5;
if(object.ReferenceEquals (i,j))Console.WriteLine("Equal");
else Console.WriteLine("Not Equal");
}
}
}

  

using System;

namespace gtkTest
{
public class MyCountClass
{
private static int count=0;
static MyCountClass ()
{
count++;
}
public MyCountClass ()
{
count++;
}
MyCountClass o1=new MyCountClass();
MyCountClass o2=new MyCountClass();
public static void MyCountClassFun ()
{
//question is o1.Count,but count static ,o1 is new not is static
Console.WriteLine("{0}",MyCountClass.count );
}
}
}

  

题五

 gtkTest .MyCallClass.MyCallClassFun();

  

using System;

namespace gtkTest
{
public class MyCallClass
{
public MyCallClass ()
{
} abstract class BaseClass
{
public virtual void MethodA(){}
public virtual void MethodB(){} }
class Class1:BaseClass
{
public void MethodA(string arg){}
public void MethodB(string arg){}
}
class Class2:Class1
{
new public void MethodB(){}
}
public static void MyCallClassFun ()
{
Class2 o= new Class2 ();
//Console.WriteLine(o.MethodA());
o.MethodA();
}
} }

  

请问, o.MethodA 调用的是? BaseClass.MethodA

    • Class2.MethodA
    • Class1.MethodA
    • BaseClass.MethodA
    • 都不是

C#笔试总结的更多相关文章

  1. C++常见笔试面试要点以及常见问题

    1. C++常见笔试面试要点: C++语言相关: (1) 虚函数(多态)的内部实现 (2) 智能指针用过哪些?shared_ptr和unique_ptr用的时候需要注意什么?shared_ptr的实现 ...

  2. 2016网易春招Java在线笔试回忆录

    别看是在线笔试,但是非常严格,全称窗口不得最小化和关闭,转移,全称需要打开摄像头监控,使用草稿纸需要摄像头对准……反正2个小时,题量在那儿摆着,有作弊的功夫不如好好做做最后的编程题呢……网易不让泄漏原 ...

  3. BAT及各大互联网公司2014前端笔试面试题--Html,Css篇

    很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习前端基础更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正 ...

  4. BAT及各大互联网公司2014前端笔试面试题--JavaScript篇

    很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习js更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正确, ...

  5. IT求职中,笔试、面试的算法准备

    PS:此文章为转载,源地址:http://www.newsmth.net/nForum/#!article/CoderInterview/849     作者应该是在美国进行的笔试面试,感觉面试的的公 ...

  6. # C/C++的笔试题目

    p,li { white-space: pre-wrap } # C/C++的笔试题目 + include<> 和include"" 的区别 + sizeof操作符与字 ...

  7. 技术渣如狗,面试虐成猴——本科楼主UC笔试加处女一面全纪录

    背景——楼主为广州某校小本一枚,学习成绩渣(班里排名几乎倒数),技术基础渣(算是会敲代码,但很多计算机网络.操作系统的知识都只有模糊的印象).在舍友的鼓励下,收到广州UC的面试通知后,勇敢来到公司直面 ...

  8. DP - tencent2016实习生笔试A

    tencent2016实习生笔试A Problem's Link ------------------------------------------------------------------- ...

  9. dp - 2016腾讯笔试 A

    2016腾讯笔试 A Problem's Link -------------------------------------------------------------------------- ...

  10. 各大IT公司校园招聘程序猿笔试、面试题集锦

    转自:http://blog.csdn.net/hackbuteer1/article/details/7959921#t4 百度一面 1.给定一个字符串比如“abcdef”,要求写个函数编程“def ...

随机推荐

  1. html script生成二维码

    <div class="code" align="center"> <p >手机端扫描以下二维码直接观看(支持安卓Android/苹果i ...

  2. 以非root身份安装Python的Module或者Package以及pip安装指定路径

    因为要远程访问公司的服务器,没有sudo的权限,所以在安装python的一些包的时候就不能安去默认路径了(比如以/usr/local/lib/为prefix的路径). 一般来讲用easy_instal ...

  3. MySQL-快速入门(9)视图

    1.什么是视图 视图是一个虚表.视图可以进行查询.增加.修改.删除.进行修改.增加.删除,将影响基本表中的数据. 2.视图相对基本表的优势 1>简单化:看到的就是想要的字段列,可以简化后续查询. ...

  4. CentOS 7 下安装.NET Core SDK 2.1

    一.RPM包安装 1.导入rpm源 sudo rpm -Uvh https://packages.microsoft.com/config/rhel/7/packages-microsoft-prod ...

  5. 《剑指offer》面试题25 二叉树中和为某一值的路径 Java版

    (判断是否有从根到叶子节点的路径,其和为给定值.记录这些路径.) 我的方法:这道题我是按照回溯的思路去做的,我们需要一个数据结构来保存和删除当前递归函数中添加的值.这里要打印一条路径,我们可以选择Li ...

  6. 【暑假培训1】test1

    T1: 30pts:直接暴力三层循环枚举 就就就先不写代码了qwq: 70pts: 因为X+Y+Z==0 所以我们可以考虑枚举X和Y,然后利用↑式子求出Z=-X-Y: 然后touli xcg的70pt ...

  7. c++ 多线程(2000个)端口扫描(附源码)

    目录 程序适应环境与基本介绍 程序适应环境与基本介绍 情况:开2000个线程,扫描主机上开启的端口,扫描时间40秒左右. 瓶颈:不管开5000还是更多,都不能大幅加快扫描时间. 瓶颈解决方法:可以使用 ...

  8. 【WPS/Visio】WPS word无法复制或编辑Visio对象

    前言 Win10,WPS2019,Visio2016. 好像是有一次设置 .vsdx 的默认打开方式为Visio,之后每次在WPS里复制Visio对象,或双击编辑WPS word中以前的Visio对象 ...

  9. 使用mysql的source批量导入多个sql文件

    需求: 有一个文件,文件里面包含100多个sql文件,想要把这些sql文件都导入到mysql中 做法: 使用 mysql 的 source 可以将文件导入到 mysql 中,但是一次只能导入一个 sq ...

  10. letsencrypt 免费SSL证书申请, 自动更新

    Let's Encrypt 泛域名 证书申请 及自动更新 关键字:SSL证书.HTTPS 初次申请 1. 下载certbot wget https://dl.eff.org/certbot-auto ...