4递归实现阶乘计算器 5递归实现TreeView绑定表MenuTree
2012-12-18 20:57
519 查看
4递归实现阶乘计算器
aspx:
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox><asp:Label ID="Label1" runat="server"
Text="的阶乘="></asp:Label><asp:TextBox ID="TextBox2" runat="server"></asp:TextBox><asp:Button
ID="Button1" runat="server" Text="计算" Xonclick="Button1_Click"
Width="57px" />
aspx.cs:
protected void Button1_Click(object sender, EventArgs e)
{
TextBox2.Text= multiply(Convert.ToInt32(TextBox1.Text)).ToString();
}
public static int multiply(int n)
{
if (n == 0)
{
return 1;
}
else
{
return n * (multiply(n - 1));
}
}
5递归实现TreeView绑定表MenuTree
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
namespace TreeViewDemo
{
public partial class TreeDemo3 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
bindTree();
}
private void bindTree()
{
DataTable dt = this.GetTreeData();
this.FillNode(dt, null);
}
private void FillNode(DataTable dt, TreeNode node)
{
DataView dv = new DataView(dt);
if (node == null) //根结点
{
dv.RowFilter = "parentid='0'"; //筛选到根结点的所有子节点
}
else //不是根结点
{
dv.RowFilter = "parentid='" + node.Value + "'"; //筛选对应节点的所有子节点
}
foreach (DataRowView drv in dv) //遍历填充节点的所有子节点,如果传入的节点node为叶子节点,遍历要退出,不再进行递归
{
TreeNode no = new TreeNode(drv["menuname"].ToString(), drv["menuid"].ToString());
FillNode(dt, no); //填充no节点的子节点
if (node == null)
{
this.TreeView1.Nodes.Add(no);
}
else
{
node.ChildNodes.Add(no);
}
}
}
private DataTable GetTreeData()
{
string strcnn = ConfigurationManager.ConnectionStrings["treeCon"].ConnectionString;
using (SqlConnection sqlcnn = new SqlConnection(strcnn))
{
SqlCommand sqlcmm = sqlcnn.CreateCommand();
sqlcmm.CommandText = "select * from MenuTree order by parentid,menuorder";
SqlDataAdapter da = new SqlDataAdapter(sqlcmm);
DataSet ds = new DataSet();
da.Fill(ds);
return ds.Tables[0];
}
}
}
}
aspx:
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox><asp:Label ID="Label1" runat="server"
Text="的阶乘="></asp:Label><asp:TextBox ID="TextBox2" runat="server"></asp:TextBox><asp:Button
ID="Button1" runat="server" Text="计算" Xonclick="Button1_Click"
Width="57px" />
aspx.cs:
protected void Button1_Click(object sender, EventArgs e)
{
TextBox2.Text= multiply(Convert.ToInt32(TextBox1.Text)).ToString();
}
public static int multiply(int n)
{
if (n == 0)
{
return 1;
}
else
{
return n * (multiply(n - 1));
}
}
5递归实现TreeView绑定表MenuTree
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
namespace TreeViewDemo
{
public partial class TreeDemo3 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
bindTree();
}
private void bindTree()
{
DataTable dt = this.GetTreeData();
this.FillNode(dt, null);
}
private void FillNode(DataTable dt, TreeNode node)
{
DataView dv = new DataView(dt);
if (node == null) //根结点
{
dv.RowFilter = "parentid='0'"; //筛选到根结点的所有子节点
}
else //不是根结点
{
dv.RowFilter = "parentid='" + node.Value + "'"; //筛选对应节点的所有子节点
}
foreach (DataRowView drv in dv) //遍历填充节点的所有子节点,如果传入的节点node为叶子节点,遍历要退出,不再进行递归
{
TreeNode no = new TreeNode(drv["menuname"].ToString(), drv["menuid"].ToString());
FillNode(dt, no); //填充no节点的子节点
if (node == null)
{
this.TreeView1.Nodes.Add(no);
}
else
{
node.ChildNodes.Add(no);
}
}
}
private DataTable GetTreeData()
{
string strcnn = ConfigurationManager.ConnectionStrings["treeCon"].ConnectionString;
using (SqlConnection sqlcnn = new SqlConnection(strcnn))
{
SqlCommand sqlcmm = sqlcnn.CreateCommand();
sqlcmm.CommandText = "select * from MenuTree order by parentid,menuorder";
SqlDataAdapter da = new SqlDataAdapter(sqlcmm);
DataSet ds = new DataSet();
da.Fill(ds);
return ds.Tables[0];
}
}
}
}
相关文章推荐
- 递归方法实现TreeView的绑定展示
- 用递归实现阶乘计算器
- 使用asp.net递归的方法来实现treeview的数据绑定
- 递归实现阶乘计算器
- 递归实现TreeView绑定表MenuTree
- TreeView数据绑定的方法(可实现无限递归)
- TreeView树形控件递归绑定数据库里的数据
- TreeView的数据源绑定—采用XML作为数据源,实现对treeview进行增删改查,之后回写XML文档
- WPF ComboBox下拉绑定Treeview 功能的实现
- WPF TreeView DataTable 绑定 实现无限层过滤
- 模版元递归实现阶乘
- C#递归实现Treeview
- C/C++程序——递归和循环实现阶乘,并比较N!与(2N N)的大小
- scheme实现匿名递归阶乘(Y组合子)
- 运用递归实现计算器加减乘除带括号优先级算法
- 汇编语言实现递归阶乘算法代码分析(8)
- ASP.NET实现TreeView的XML数据源绑定
- 递归实现(汉诺塔+阶乘)
- C# 递归的应用 TreeView递归绑定数据
- C# 里TreeView绑定数据库实现分类