例程终结者 2023-01-09 17:09 采纳率: 86.4%
浏览 22
已结题

C#有多个返回值的函数如何实现递归

问题遇到的现象和发生背景

C#有多个返回值的函数如何实现递归

用代码块功能插入代码,请勿粘贴截图。 不用代码块回答率下降 50%
  public static List<OrderData> nextpoint(List<NewTrackData> currentlist, int currentpoint, NewTrackData currentpoint2)//当前list,当前点
        {
            double  distence;
            double minidistence;
            Distencelist.Clear();
            for (int i = 0; i < currentlist.Count; i++)//去掉第一个点的新list
            {
                distence = Math.Pow((currentlist[i].Track.Start_X - currentpoint2.Track.Start_X), 2.0) + Math.Pow((currentlist[i].Track.Start_Y - currentpoint2.Track.Start_Y), 2.0);
                Distencelist.Add(distence);
            }
            minidistence = Distencelist.Min();//获取list中的最小值
            List<int> minilist = new List<int>();
            int minIndex = Distencelist.IndexOf(minidistence);//获取最小值的索引集合
            for (int i = minIndex; i < Distencelist.Count; i++)
            {
                if (Distencelist[i] == minidistence)
                {
                    minilist.Add(i);
                }
            }
             List<int> index = new List<int>();
             for (int i = 0; i < minilist.Count; i++)
             {
                 index.Add(currentlist[minilist[i]].originalIndex);
             }
             List<NewTrackData> newlistreproduct = new List<NewTrackData>();
             newlistreproduct = currentlist.GetRange(0, currentlist.Count);
             OrderData temp = new OrderData();
             List<OrderData> OrderData = new List<OrderData>();   
             temp.orderlist = index.GetRange(0, index.Count);
             OrderData.Add(temp);
             if (currentlist.Count == 0)
             {
                 return OrderData;
             }
             else
             {
                 for (int i = 0; i < index.Count; i++)
                 {
                     NewTrackData tempcurrentpoint = new NewTrackData();
                     tempcurrentpoint = newlistreproduct[index[i]];
                     newlistreproduct.RemoveAt(index[i]);
                     List<OrderData> OrderData2 = nextpoint(newlistreproduct, index[i], tempcurrentpoint);
                     OrderData.Add(OrderData2[i]);
                 }
                 return OrderData;
             }
        }
运行结果及详细报错内容
我的解答思路和尝试

函数返回值可能是多个值,或一个值,如何设计递归?上述函数的思路是:求出list数组中剩余项中距离当前项最小距离,然后去除当前项,再求剩余项中距离当前项最小距离,循环递归直到list为空,但是遇到问题是,距离当前项的最小距离有相同的项,不是唯一的,例如第三项,第四项距离当前项距离一致且都为最小距离,再循环递归就出现两个分支。

我想要达到的结果,如果你需要快速回答,请尝试 “付费悬赏”
  • 写回答

2条回答 默认 最新

  • dmm128073411 2023-01-20 23:16
    关注

    用全局变量

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月11日
  • 已采纳回答 4月3日
  • 创建了问题 1月9日

悬赏问题

  • ¥15 请问读取环境变量文件失败是什么原因?
  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载