-1

我编写了这段代码来生成两个项目集。

我正在编写list<list<>>列表列表以生成两个项目集,并希望优化代码以生成长度为 k 的项目集。

using System.Data.OleDb;
using Microsoft.AnalysisServices.AdomdClient;

namespace HW3
{
    class Program
    {
        private static int Min_support = 360;
        private static List<String> itemSet = new List<string>();
        private static List<List<String>> C_itemSet = new List<List<string>>();

        static void Main(string[] args)
        {
            List_Movies();
            //for (int k = 1; k < 3; k++)
            //{ }
            C_itemSet = Geneate_Sets(itemSet);

            for (int i = 0; i < C_itemSet.Count; i++)
            {
                for (int j = 0; j < C_itemSet[i].Count; j++)
                {
                    Console.Write(C_itemSet.ElementAt(i).ElementAt(j));
                }
                Console.WriteLine();
            }

            Console.ReadKey();
        }

        private static void List_Movies()
        {
            string connectionString = @"Provider=SQLOLEDB;Server=.;AttachDbFilename=D:\DBs\MovieClick.mdf;Database=dbname; Trusted_Connection=Yes;";
            OleDbConnection myConn = new OleDbConnection(connectionString);
            myConn.Open();
            string str = "select Movie,COUNT(Movie) from Movies group by Movie HAVING COUNT(MOVIE) > "+Min_support;
            OleDbCommand myComm = new OleDbCommand(str, myConn);
            OleDbDataReader DR = myComm.ExecuteReader();
            while (DR.Read())
            {
                if (DR[0] != null)
                    itemSet.Add(DR[0].ToString()); // Movie name
            }

            myConn.Close();
        }

        private static List<List<String>> Geneate_Sets(List<String> fSet )
        {
            List<List<String>> finalSet= new List<List<string>>();
            for (int i = 0; i < fSet.Count; i++)
            {
                for (int j = i+1; j < fSet.Count; j++)
                {
                    if (!fSet[i].Equals(fSet[j]))
                    {
                        List<string> temp = new List<string>();
                        temp.Add(fSet[i]);
                        temp.Add(fSet[j]);

                            finalSet.Add(temp);
                    }
                }
            }
            return finalSet;
        }
4

1 回答 1

0

除非您的数据真的非常庞大,否则我建议您将其加载到已经正确实施 Apriori 的好库中。

因为从您的代码来看,您与 Apriori 实现相距甚远,尤其是实际上执行良好的实现,抱歉。照原样,您似乎还没有任何 APRIORI。不要指望我们为您编写算法。

于 2014-03-31T09:16:06.207 回答