文韬 的个人资料菠萝的天空照片日志列表更多 工具 帮助

日志


3月17日

答案(仿佛更抽象)^_^

    class begin
    {   
        static void Main()
        {
            //初始化生日集合         
            生日集合 srjh=new 生日集合();
            srjh.Add(new 生日类(3,4));
            srjh.Add(new 生日类(3,5));
            srjh.Add(new 生日类(3,8));
            srjh.Add(new 生日类(6,4));
            srjh.Add(new 生日类(6,7));
            srjh.Add(new 生日类(9,1));
            srjh.Add(new 生日类(9,5));
            srjh.Add(new 生日类(12,1));
            srjh.Add(new 生日类(12,2));
            srjh.Add(new 生日类(12,8));
          
            //开始工作流
            工作流.BEG(srjh);           
            System.Console.Read();
        }   
    }
//工作流
    class 工作流
    {
        /**//*    开始结点
         *     ↓
         *    结点A:如果我不知道的话 →结点X:小明知道(该节点分支略)
         *     ↓
         *    结点B:小强肯定也不知道
         *     ↓
         *    结点C: 小强说:现在我知道了
         *     ↓
         *    结点D:小明说:哦,那我也知道了
         *     ↓
         *    结束结点
         *
         */
     
        public static void BEG(生日集合 obj)
        {
            if(obj !=null)
            {  
                A(obj);//下一结点
            }
        }
        //结点A:如果我不知道的话
        private static void A(生日集合 obj)
        {
            生日集合 jh=AI.小明分析(obj);
            if(jh.Count==0)
            {
                B(obj); //下一结点
            }
            else
            {
                //小明可以光凭月知道的集合
                //该节点分支略
            }
        }
        //结点B:小强肯定也不知道
        private static void B(生日集合 obj)
        {
            //得到小强光凭日期就能知道的集合
            生日集合 小强知道的集合=AI.小强分析(obj);
            //小明之所以知道小强肯定不知道,
            //是因为小明知道的月份不是小强光凭日期就能知道的
                    
            生日集合 排除的集合=new 生日集合();
            foreach(生日类 temp in 小强知道的集合)
            {
                foreach(生日类 tp in obj)
                {
                    if(temp.月==tp.月)
                    {
                        排除的集合.Add(tp);
                    }
                }
            }
            集合操作.排除(obj,排除的集合);
            C(obj);//下一结点
        }
   
        //结点C: 小强说:现在我知道了
        private static void C(生日集合 obj)
        {
            生日集合 小强知道的集合=AI.小强分析(obj);
            D(小强知道的集合); //下一结点
        }
        //结点D:小明说:哦,那我也知道了
        private static void D(生日集合 obj)
        {
            生日集合 小明知道的集合=AI.小明分析(obj);
            END(小明知道的集合);//下一结点
        }
        //完成结点:
        private static void END(生日集合 obj)
        {
            //完成,输出到屏幕
            foreach(生日类 temp in obj)
            {
                System.Console.WriteLine(temp.月.ToString() +"-" +temp.日.ToString());
            }
        }
    }
    //功能扶助类
    class 集合操作
    {
        public static void 排除(生日集合 s,生日集合 v)
        {
            foreach(生日类 temp in v)
            {
                s.Remove(temp);
            }
        }
    }
   
    class 生日类
    {
        public int 日=0;
        public int 月=0;
        public 生日类(int y,int r)
        {
            日=r;
            月=y;
        }
    }
   
    class 生日集合:System.Collections.ArrayList
    {
        public void 添加(生日类 v)
        {
            this.Add(v);
        }
        public void 移除(生日类 v)
        {
            this.Remove(v);
        }
    }
    class AI
    {
        public static 生日集合 小明分析(生日集合 v)
        {
            //AI,如果有维一的月份,则小明能确定
            //月份为1到12
            生日集合 jh=new 生日集合();
            int n=0;//记数器,如果n=1表示有
            for(int i=1;i<=12;i++)
            {
                生日类 x=null;
                foreach(生日类 temp in v)
                {
                    if(temp.月==i)
                    {
                        n=n+1;
                        x=temp;
                    }                  
                }
                    if(n==1)
                    {
                        jh.Add(x);
                    }
                n=0;
            }
            return jh;
        }
        public static 生日集合 小强分析(生日集合 v)
        {
            //AI,如果有维一的日,则小强能确定
            //日为1到31
            生日集合 jh=new 生日集合();
            int n=0;//记数器,如果n=1表示有
            for(int i=1;i<=31;i++)
            {
                生日类 x=null;
                foreach(生日类 temp in v)
                {
                    if(temp.日==i)
                    {
                        n=n+1;
                        x=temp;
                    }   
                }
                if(n==1)
                {
                    jh.Add(x);
                }
                n=0;
            }
            return jh;
        }
    }

评论

请稍候...
很抱歉,您输入的评论太长。请缩短您的评论。
您没有输入任何内容,请重试。
很抱歉,我们当前无法添加您的评论。请稍后重试。
若要添加评论,需要您的家长授予您相应权限。请求权限
您的家长禁用了评论功能。
很抱歉,我们当前无法删除您的评论。请稍后重试。
您已超过了一天之内允许提供的评论数上限。请在 24 小时后重试。
因为我们的系统表明您可能在向其他用户提供垃圾评论,您的帐户已禁用了评论功能。如果您认为我们错误地禁用了您的帐户,请联系 Windows Live 支持部门
完成下面的安全检查,您提供评论的过程才能完成。
您在安全检查中键入的字符必须与图片或音频中的字符一致。

若要添加评论,请使用您的 Windows Live ID 登录(如果您使用过 Hotmail、Messenger 或 Xbox LIVE,您就拥有 Windows Live ID)。登录


还没有 Windows Live ID 吗?请注册

引用通告

此日志的引用通告 URL 是:
http://mxtaker84.spaces.live.com/blog/cns!A12A975023687B23!446.trak
引用此项的网络日志