[CODE=cplusplus]
/*List.h*/
#ifndef _LIST_H
#define _LIST_H
#define LIST_INIT_SIZE 100
#define LISTINCREMENT 10
template
class List
{
public:
List(); //构造函数:构造一个空的线性表
//~List(); //析构函数
void DestroyList(); //销毁线性表
void ClearList(); //将表重置为空表
bool ListEmpty(); //若为空表存在返回True
int ListLength(); //返回表中数据元素个数
T GetElem(int i,T &e); //用e返回表中第i个元素的值
int LocateElem(T e); //返回表中第一个e元素的位置
T PriorElem(T cur_e,T &pre_e); //返回前驱
T NextElem(T cur_e,T &next_e); //返回后继
void ListInsert(int i,T e); //在第i个元素插入值e
T ListDelete(int i,T &e); //删除第i个元素的值并返回
void ListTraverse(void visit()); //对每个元素进行visit()

private:
T *elem;
int length;
int listsize;
};

//构造一个空的线性表
template
List::List()
{
elem=(T *)malloc(LIST_INIT_SIZE*sizeof(T)); /*分配空间*/
if(!elem)
throw “Allocation failed”;
else
{
length=0;
listsize=LIST_INIT_SIZE;
}
}
//销毁线性表
template
void List::DestroyList()
{
free(elem);
}
//将表重置为空表
template
void List::ClearList()
{
length=0;
}
//若为空表存在返回True
template
bool List::ListEmpty()
{
return length ? true :false;
}
//返回表中数据元素个数
template
int List::ListLength()
{
return length;
}
//用e返回表中第i个元素的值
template
T List::GetElem(int i,T &e)
{
if(i<1||i>length)
throw “Index out of bounds”;
else
e=elem[i-1];
return e;
}
//返回表中第一个e元素的位置
template
int List:: LocateElem(T e)
{
for(int i=0;i {
if(elem[i]==e)
return i+1;
}
cout<<"表中不存在值为"< return 0;

}
//返回前驱
template
T List::PriorElem(T cur_e,T &pre_e)
{
int i=LocateElem(cur_e);
if(i>1)
{
pre_e=elem[i-2];
return pre_e;
}
else
return NULL;
}
//返回后继
template
T List::NextElem(T cur_e,T &next_e)
{
int i=LocateElem(cur_e);
if(i>0&&i {
next_e=elem[i];
return next_e;
}
else
return NULL;
}
//在第i个元素插入值e
template
void List::ListInsert(int i,T e)
{
if(i<0||i>length+1) cout<<"error!";
else if(i==length)
{
elem = (T *)realloc(elem,(length+LISTINCREMENT)*sizeof(T));
}
for(int j=length;j>=i;j–) elem[length]=elem[length-1];
elem[i-1]=e;
length++;
}
//删除第i个元素的值并返回
template
T List::ListDelete(int i,T &e)
{
if(length==0) return NULL;
if(i<0||i>length) return NULL;
e=elem[i-1];
for(int j=i;j length–;
return e;
}
//对每个元素进行visit()
template
void List::ListTraverse(void visit())
{
for(i=0;i}

#endif

//程序测试文件,http://blog.ourys.com/原创,做人好厚道,转载请表明出去

#include
#include “List.h”
using namespace std;
int main()
{

List list;
for(int i=0;i<10;i++) list.ListInsert(i+1,i*(1+i));
int a[10],b[10];
for(int i=0;i cout< list.NextElem(0,b[0]);
cout< cout< for(int i=0;i return 0;
}
[/CODE]

就从我自己的亲身经历说起吧,我最初做了一个电影站,05td。cn的域名,可是推广技巧不够好,被K了(可以从我亲身经历的另一篇日志看如何推广自己的网站,地址http://www.ourys.com/post/35.html),当时相当的伤心,没有办法,之后只好重新申请一个域名www.ourys.com,非常高兴能够申请到这么好的一个域名,心里非常高兴。

但是如果www.ourys.com是一个被k过或者作弊过的域名,那么对于我的网站的流量特别是在搜索引擎中的表现,那就有很大的影响了。域名的选择对于一个网站来说至关重要,那么究竟如何能判断一个域名是否被搜索引擎k过呢?现在就我如何查询www.ourys.com这个域名,希望对大家能有所帮助。

1.首先,到域名查询中心像万网或者能查询域名情况的地方去查下域名的注册信息,是否以前被注册过 http://whois.domaintools.com 这个网站提供查询功能,而且功能还很强大,可以看看其他功能。经过查询发现这个域名03年左右被注册过,过了这么多年,这点我放心了。如果域名曾经被注册过,就要小心了,然后再查看下是否有被k过的记录。

2.通过(site:域名),看下是否有记录,然后查看下反向链接,利用(link:域名)或者(domain:域名)也可以到一些提供查询反向连接的网站去查询或者自己到搜索引擎利用命令查询,如果有反向连接,而site却没有结果,那么这个域名很有可能被k了。经过我的查询,www.ourys.com没有这方面的迹象,这下我放心了。

3.查询域名是否做过网站,打开http://web.archive.org/web/ 输入自己想要查询的域名然后按Take Me Back,如果做过网站都会有数据显示出来。查过之后,虽然www.ourys.com有过记录,但是这么好一个域名我也舍不得,最后还是申请了。

4.直接输入网址有记录,而site却没有记录,那么也有可能被k过了。

5.通过查看域名历史页面和世界排名以及alexa排名 也能看出来这个域名被使用过没有。

下面浅谈一下怎样让自己的域名在最短的时间内被各大搜索引擎收录,因为我认为只有分享才是互联网的最终精神:

    1、给我的站点增加一个robots.txt:因为搜索引擎抓取网站首先是判断你的网站根目录下有没有robots.txt。如果不禁止搜索引擎抓取自己站点的任何内容,可以放一个空的文件。也可以写成下面的红色部分的内容(我的电影站www.ourys.com就是这么写的):
    User-agent: *

    2、提交你的网站,你可以登陆各大搜索引擎提交你的网站,不过我有更好的方法,就是利用他们的人工服务,比如google下面的与google对话,这样他们的工作人员看见你的建议之后会人为的收录你的网站,这样速度更快。

    3、发软文吸引蜘蛛:新注册的域名不可能有权威值,只有多写一些原创的文章,或者把别人的东西拿来修改一下,即所谓的“伪原创”。为此,你可以到admin5站长站、中国站长站和站长中国等站长类网站投稿,吸引蜘蛛。

    4、在一些著名的it网站申请博客,如艾瑞网、donews、csdn、17Tech等,把我的这篇文章发布出去。

   5、在一些论坛呀,百度知道里面回答问题加入你的网站地址(注意千万不要到百度贴吧,必死无疑),增加你的反向链接。

    6、给网站增加一个流量统计工具。

    7、进google的网站管理员工具,把网址增加到里面,并验证通过。这个对google的收录非常重要。

    8、提交给一些有名的dig类网站,如果不知道你可以在百度和google里搜索一下。

    9、如果你的网站有ping功能,那太好了,可以直接去google的blog搜索里去ping一下,那样速度会更快。

   10、写博客,各类搜索引擎喜欢收录博客,你可以建立自己的博客(比如我的http://www.ourys.com/blog/),还有百度空间呀,网易空间等等,写日志,里面加上你的域名。

    站点的程序不同,可以推广的方式有点不同,我的网站用css静态页面,所以很受搜索引擎欢迎,代码简单,但是不利于推广。其他可用来推广网站的方法有提交给网摘、书签等站点。
 

1、ASP两种简单的生成静态首页的方法
为什么要生成静态首页?
1、如果你首页读取的数据库次数比较多,速度很慢,而且占用很多服务器资源。使用静态页面访问速度当然快多了
2、搜索引擎容易搜索到
3、如果程序出问题,也能保证首页能访问。
4、其他的太多,自己想:)

本文来自:http://www.ourys.com/blog
应用方式:
如果你的首页是index.asp,你可以生成index.htm (默认访问顺序必须是index.htm,index.asp)。这样访问者第一次访问到你的网站的时候打开的是index.htm 。你可以把网站首页的链接做成index.asp,这样从网站任何一个页面点击首页的链接出现的就是index.asp,这样保证的信息更新的及时性(毕竟index.htm需要每次手动更新)。
方法一:
直接将首页文件包含在表单文本框中,将首页代码最为数据提交,然后生成静态页面。
代码如下:
<%
‘————————————————————
‘使用表单提交生成静态首页的代码
‘确保你的空间支持FSO,且首页代码内容较少
‘————————————————————
dim content
content=Trim(Request.Form("content"))
if content<>"" then
call makeindex()
end if
sub makeindex()
  Set Fso = Server.CreateObject("Scripting.FileSystemObject")
  Filen=Server.MapPath("index.htm")
  Set Site_Config=FSO.CreateTextFile(Filen,true, False)
  Site_Config.Write content
  Site_Config.Close
  Set Fso = Nothing
  Response.Write("<script>alert(‘已经成功生成首页!’)</script>")
end sub
%>
<form name="form1" method="post" action="">
 <textarea name="content">
<!– #i nclude file="index.asp" –>
</textarea>
 <br>
 <input type="submit" name="Submit" value="提交">
</form>
缺点:
1、如果首页中包括<@ ..>标记,会提示出错。
2、如果首页代码较长,用表单无法提交过去(表单数据长度有一定的限制)。
解决方案:
1、去掉index.asp中的<@ >标记
2、使用eWebEditor,提交支持大数据(能自动分割)
优点:
可以在生成时对内容实时修改。
方法二:
直接使用XMLHTTP获取index.asp的代码

<%
‘———————————————————-
‘使用XMLHTTP生成静态首页的代码
‘Curl 为你的首页地址,确保你的空间支持FSO
‘———————————————————–
dim read,Curl,content
Curl="http://www.ourys.com/index.asp"
read=getHTTPPage(Curl)
if read<>"" then
  content=read
  call makeindex()
end if
sub makeindex()
  Set Fso = Server.CreateObject("Scripting.FileSystemObject")
  Filen=Server.MapPath("index.htm")
  Set Site_Config=FSO.CreateTextFile(Filen,true, False)
  Site_Config.Write content
  Site_Config.Close
  Set Fso = Nothing
  Response.Write("<script>alert(‘已经成功生成首页!’)</script>")
end sub
Function getHTTPPage(url)
  dim http
  set http=Server.createobject("Microsoft.XMLHTTP")
  Http.open "GET",url,false
  Http.send()
  if Http.readystate<>4 then
    exit function
  end if
  getHTTPPage=bytesToBSTR(Http.responseBody,"GB2312")
  set http=nothing
  if err.number<>0 then err.Clear
End function
Function BytesToBstr(body,Cset)
  dim objstream
  set objstream = Server.CreateObject("adodb.stream")
  objstream.Type = 1
  objstream.Mode =3
  objstream.Open
  objstream.Write body
  objstream.Position = 0
  objstream.Type = 2
  objstream.Charset = Cset
  BytesToBstr = objstream.ReadText
  objstream.Close
  set objstream = nothing
End Function
%>

2、模板分离批量生成

模板文件中要替换的内容均以{…}括起来

为力求简洁,去掉了错误处理代码(replace中要来替换的字符串参数不能为null值,当然fso也应该做错误检查)。
<%
Dim start ‘该变量为指针将要指向的记录集位置,通过参数动态获得
Dim Template ‘模板文件将以字符串读入该变量
Dim content ‘替换后的字符串变量
Dim objConn ‘连接对象
Dim ConnStr ‘连接字符串
Dim sql ‘查询语句
Dim cnt:cnt = 1 ‘本轮循环计数器初始化

start = request("start") ‘获取本轮指针的开始位置
If IsNumeric(start) Then start = CLng(start) Else start=1
If start=0 Then start = 1 ‘如果start

ConnStr = "Provider = Microsoft.Jet.OLEDB.4.0;Data Source = " & Server.MapPath("DataBase.mdb")
sql = "select * from table_name"

Set objConn = Server.CreateObject("ADODB.Connection")
objConn.Open ConnStr

set rs = Server.CreateObject("ADODB.Recordset")
rs.open sql,objConn,1,1 ‘打开数据集
rs.AbsolutePosition = start ‘最关键的一步,将指针指向start,start通过参数动态获得

Template = getTemplate(Server.MapPath("template.html"))’ template.html为模板文件,通过函数getTemplate读入到字符串,模板文件中要替换的内容均以{…}括起来

While Not rs.eof And cnt<= 500 ‘500是设定一次请求生成页面的循环次数,根据实际情况修改,如果太高了,记录集很多的时候会出现超时错误
content = Replace(Template,"{filed_name_1}",rs("filed_name_1")) ‘用字段值替换模板内容
content = Replace(content,"{filed_name_2}",rs("filed_name_2"))
……
content = Replace(content,"{filed_name_n}",rs("filed_name_n"))

genHtml content,Server.MapPath("htmfiles/"&rs("id")&".html") ‘将替换之后的Template字符串生成HTML文档,htmfiles为存储静态文件的目录,请手动建立

cnt = cnt + 1 ‘计数器加1
start = start + 1 ‘指针变量递增
rs.movenext
wend

If Not rs.eof Then ‘通过刷新的方式进行下一轮请求,并将指针变量start传递到下一轮
response.write "<meta http-equiv=’refresh’ content=’0;URL=?start="&start&"’>"
Else
response.write "生成HTML文件完毕!"
End if

rs.Close()
Set rs = Nothing
objConn.Close()
Set objConn = Nothing

Function getTemplate(template)’读取模板的函数,返回字符串,template为文件名
Dim fso,f
set fso=CreateObject("Scripting.FileSystemObject")
set f = fso.OpenTextFile(template)
getTemplate=f.ReadAll
f.close
set f=nothing
set fso=Nothing
End Function

Sub genHtml(content,filename)’将替换后的内容写入HTML文档,content为替换后的字符串,filename为生成的文件名
Dim fso,f
Set fso = Server.CreateObject("Scripting.FileSystemObject")
Set f = fso.CreateTextFile(filename,true)’如果文件名重复将覆盖旧文件
f.Write content
f.Close
Set f = Nothing
set fso=Nothing
End Sub
%>