목록을 사용자 정의 크기의 작은 목록으로 분할
목록을 특정 크기의 더 작은 목록으로 분할할 때 잘못된 목록 분할이 발생하면 실망스러울 수 있습니다. 크기가 30 이하인 목록으로 정확하게 분할되도록 splitList
함수를 수정하는 방법을 살펴보겠습니다.
원래 함수의 문제는 루프 계산입니다: for (int i=(int)(Math.Ceiling((decimal)(locations.Count/nSize))); i>=0; i--)
. 원하는 하위 목록 수에서 0까지 반복하는 대신 더 높은 값에서 반복하여 잘못된 분할이 발생합니다.
업데이트된 기능은 다음과 같습니다.
<code class="language-c#">public static List<List<float>> splitList(List<float> locations, int nSize = 30) { List<List<float>> list = new List<List<float>>(); int numLists = (int)(Math.Ceiling((decimal)(locations.Count / nSize))); for (int i = 0; i < numLists; i++) { List<float> subLocat = new List<float>(locations); // 创建locations的副本 if (subLocat.Count >= ((i * nSize) + nSize)) subLocat.RemoveRange(i * nSize, nSize); else subLocat.RemoveRange(i * nSize, subLocat.Count - (i * nSize)); Debug.Log("Index: " + i.ToString() + ", Size: " + subLocat.Count.ToString()); list.Add(subLocat); } return list; }</code>
이 업데이트된 버전에서는 루프가 0부터 원하는 하위 목록 수(numLists)까지 반복됩니다. 이렇게 하면 함수가 적절한 위치에서 분할을 시작합니다. 또한 코드는 List<float> subLocat = new List<float>(locations);
을 사용하여 locations
의 복사본을 생성하여 원본 목록이 수정되는 문제를 방지합니다.
위 내용은 목록을 사용자 정의 크기(예: 30개 이하)의 더 작은 목록으로 올바르게 분할하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!