演示索引指示器的用法(C#)
// 本演示测试连续自然数中的质数的个数,质数就是除了1和它本身能整除为,不能被别人整除了.
// 不好意思,小时候数学学的不好,关于怎么判断质数的算法我没有理解透澈呢,不过这不影响你了解索引指示器的建立和使用,大家谁懂,麻烦指点一下哦
// 注释比较多,如果去除所有注释,代码还是很紧凑的,没办法,现在就得做一些很基础的练习.
using System; //导入命名空间
class BitArray //定义一个类BitArray
{
int[] bits; //定义一个int型数组
int length; //定义一个int变量,注意:没有修饰符的变量默认是私有变量
public BitArray(int length) { //定义这个类的构造函数,在C#中用类的同名函数来做构造函数,在VB.NET用new关键字定义
if (length<0) throw new ArgumentException(); //如果长度小于0的话抛出一个ArgumentException异常
bits=new int[((length-1)>>5)+1]; //给bits数组赋值,并把length减去1向右移位5最后再加1
this.length=length; //用参数length为私有变量length赋值,注意this关键字的用法,这里表示正在引用的类,也就是class BitArray,this还有别的用法
}
public int Length { //设置一个只读属性,
get { return length; } //属性返回私有变量length的值,注意大小写哦,呱呱.
}
public bool this[int index] { //构建一个可读写索引指示器
get { //设置get指示器
if (index<0 || index>=length) { //如果传递的索引值小于0或者大于数组边界的话引发一个IndexOutOfRangeException异常
throw new IndexOutOfRangeException();
}
return (bits[index>>5]&1<<index)!=0; //,如果是质数就返回1,如果不是质数就返回1,不要问我这个位算法和质数的关系哦,我可不懂位和汇编等底层的东西.
}
set { //设置set指示器
if (index<0 || index>=length) { //和get访问起一样,先检查输入的索引是否在合适的范围内,在实际编程中应该也有责任做这些潜在的错误处理,这能增强程序的健壮性
throw new IndexOutOfRangeException();
}
if (value) {
bits[index>>5] |= 1<<index;
}
else {
bits[index>>5] &= ~(1<<index);
}
}
}
}
class Sample //创建一个Sample类
{
static int Count(int max) { //定义一个静态的int类型的方法
BitArray flags=new BitArray(max+1); //实例化BitArray类,并用max参数来初始化
int count=1; //定义一个int类型的count变量,并初始化为1
for (int i=2;i<=max;i++) { //定义一个循环,范围是从2-max,因为每个数肯定能整除1,所以略过.
if (!flags[i]) { //调用BitArray类的实例flags的索引指示器,
for (int j=i*2;j<=max;j+=i) flags[j]=true; //不懂
count++; //每循环一次,让count加1,
}
}
return count; //返回count
}
static void Main(string[] args) { //设置主函数,注意数组作为参数的用法
int max=int.Parse(args[0]); //获取数组参数的第一个值
int count=Count(max); //调用Count方法来处理max,
Console.WriteLine("从1到{0}之间共有{1}个质数",max,count); //向屏幕打印处理结果.
}
}
下一篇:ASP.NET中的ViewState >>
相关文章:
- · 转贴(电脑报):VBA开发实用指南
- · 蛙蛙推荐: 用web服务传递Dataset的一个简单例子
- · ASP中轻松实现变量名-值变换
- · J2EE还是.NET,这是一个问题
- · VML应用
- · Caching in ASP.NET
- · asp论坛在线人数统计研究
- · 为freetextbox1.6.5上传图片加上水印
- · 自定义配置节处理实现个性化web.config
- · 使用xmlhttp为网站增加股市行情查询功能
- · .Net Enterprise服务器可能太早冠上.Net名号了
- · 维护ASP的会话状态
- · 浅谈引用计数
- · 使你的窗体保留在桌面的最上面
- · 研究心得------->Seskin控件包中SeskinEdit汉字问题的解决办法
- · 建立三层结构的ASP应用程序
- · 研究心得------->CPU信息的获得,比较全面的
- · Sender 的??用:所有Edit共用一???^?V格式
- · override deal with window closing in database application
- · C++ 和 Delphi 的函数覆盖(Override)与重载(overload
- · 正确处理ASP动态网页中的容错机制
- · 几例在ASP存储过程的使用方法
- · 实现让每句话的头一个字母都大写
- · 如何尽快释放掉Connection对象建立的连接?
- · Connection对象的应用
- · 利用ASP打造网站论坛DIY
- · Asp中代码与页面的分离
- · 一个ASP版的图片浏览管理器
- · 实现有管理功能的ASP留言板
- · 编译asp应用程序成为exe文件
- · 如何准确定时运行ASP文件
- · ASP整合的一个SQL语句类
- · Jmail发信的实例,模块化随时调用
- · ASP字数计算函数
- · 无刷新随时取得用户当前活动信息
- · ASP自定义函数,仿VBA中域函数DLookup
- · asp中对ip进行过滤限制函数
- · 让ASP程序运行于非Windows平台
