在编译单声道(作业相关)时,C#列表出现问题

前端之家收集整理的这篇文章主要介绍了在编译单声道(作业相关)时,C#列表出现问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我承认这是我的家庭作业.任务声明说,我必须编写一个程序,找到由标准输入输入的图形的拓扑顺序.然后我需要提交它在教授的服务器上分级.

现在不是算法的问题.这更是一个技术问题.在我的电脑中,我使用.NET编译器(csc),而教授的分级机使用某种形式的单声道.

工作顺利,直到学生说我有30/100.我的一个朋友建议我使用平地机的“手动输入系统”,所以在这里我去,我创建了邻接列表的数组的100000列表.

毕业生几秒钟后,报告说我的程序已经崩溃了.

  1. Stacktrace:
  2.  
  3. at (wrapper managed-to-native) object.__icall_wrapper_mono_object_new_fast (intptr) <0x00004>
  4. at (wrapper managed-to-native) object.__icall_wrapper_mono_object_new_fast (intptr) <0xffffffff>
  5. at System.Exception.ToString () <0x00026>
  6. at (wrapper runtime-invoke) object.runtime_invoke_object__this__ (object,intptr,intptr) <0xffffffff>
  7. at (wrapper managed-to-native) object.__icall_wrapper_mono_object_new_fast (intptr) <0x00004>
  8. at (wrapper managed-to-native) object.__icall_wrapper_mono_object_new_fast (intptr) <0xffffffff>
  9. at System.Exception.ToString () <0x00026>
  10. at (wrapper runtime-invoke) object.runtime_invoke_object__this__ (object,intptr) <0xffffffff>
  11. at (wrapper managed-to-native) object.__icall_wrapper_mono_object_new_fast (intptr) <0x00004>
  12. at (wrapper managed-to-native) object.__icall_wrapper_mono_object_new_fast (intptr) <0xffffffff>
  13. at System.Exception.ToString () <0x00026>
  14. at (wrapper runtime-invoke) object.runtime_invoke

这对我来说有点奇怪,令人不安,但我还没有找到答案.再次,这个程序在我的电脑上工作得很好.

这是我的程序部分:

  1. using System;
  2. using System.Collections;
  3. using System.Collections.Generic;
  4.  
  5. class topo{
  6. public static void Main(){
  7. string[] ST = Console.ReadLine().Split(' ');
  8. int N=Convert.ToInt32(ST[0]),M=Convert.ToInt32(ST[1]);
  9. int[] ins = new int[N]; //node's total in-degrees
  10. List<int>[] E = new List<int>[N];
  11.  
  12. for(int n=0;n<N;n++)
  13. E[n] = new List<int>();
  14.  
  15. for(int m=0;m<M;m++){
  16. ST = Console.ReadLine().Split(' ');
  17. int u = Convert.ToInt32(ST[0]);
  18. int v = Convert.ToInt32(ST[1]);
  19. E[u-1].Add(v-1);
  20. ins[v-1]++;
  21. }
  22.  
  23. Queue S = new Queue();
  24. List<int> L = new List<int>(); //result list
  25.  
  26. for(int n=0;n<N;n++){
  27. //add stranded nodes directly and don't process it
  28. if(ins[n]==0 && E[n].Count==0)
  29. L.Add(n);
  30.  
  31. //put into queue
  32. else if(ins[n]==0)
  33. S.Enqueue(n);
  34. }
  35.  
  36. while(S.Count>0){
  37. int n = (int) S.Dequeue();
  38. L.Add(n);
  39. foreach(int m in E[n])
  40. if(--ins[m]==0)
  41. S.Enqueue(m);
  42. }
  43.  
  44. foreach(int n in L)
  45. Console.WriteLine(n+1);
  46.  
  47. }
  48.  
  49. }

非常感谢,我感谢任何回应.

编辑:我再次看了一下分级生的输出,看看我是否错过了什么,其实我也是这样.它说“syscal:2”,但我所知道的是“程序没有正常退出”.

编辑#2:我试图使程序尝试制作各种大小的数组列表,范围从5000,10000等,并且在40000之后,“手动输入系统”表示程序有一个System.OutOfMemoryException.进一步了解学生被允许入学的各个部分,似乎教授错误地分配了他的分级参数,并给予我们比宣布的记忆少. (他说“32MB”,但程序崩溃约16MB)

我向他报告了错误,他(现在)看着它.

解决方法

如果u或v的值小于1,则以下代码将失败.
  1. for(int m=0;m<M;m++){
  2. ST = Console.ReadLine().Split(' ');
  3. int u = Convert.ToInt32(ST[0]);
  4. int v = Convert.ToInt32(ST[1]);
  5. E[u-1].Add(v-1);
  6. ins[v-1]++;
  7. }

因为u-1或v-1将是否定的,那会引发异常.

猜你在找的C#相关文章