- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
好吧,我一直在争论是否要问并保留这个问题,看看是否能得到一些答案。我已经修复了大部分错误,但我对这个 LinkedList 有一个很大的问题。现在,它不断删除第一个节点后面的所有节点,并显示除最后一个节点之外的所有节点。我似乎无法弄清楚我的问题出在哪里。我一直在使用 jgrasp 中的调试来提供帮助,但它并没有太大帮助
我已经为那些想要运行它并看看会发生什么的人提供了我正在处理的两个文件
文件输入是一个文本文件,其内容类似于:
1,10
5,16
2,7
4,12
3,19
6,25
9,13
7,21
8,4
它也需要一个代表时间的整数。我已经 使用5
这是我的主文件:
import java.util.*;
import java.io.*;
public class Test_RoundRobin{
public static void main(String args[]) throws IOException {
LinkedList list=new LinkedList();
String file=args[0];
int cpuTime=Integer.parseInt(args[1]);
Scanner fin=new Scanner(new FileReader(file));
String pattern=",";
fin.useDelimiter(pattern);
while(fin.hasNext()){
String s=fin.nextLine();
String[] array=s.split(pattern);
int pid=Integer.parseInt(array[0]);
int time=Integer.parseInt(array[1]);
list.add(pid, time);
}
fin.close();
System.out.println(list);
list.sortList();
System.out.println(list);
int count=1;
while(list.size!=0){
list.timeSlice(cpuTime);
System.out.println("Run " + count + ": " + list);
count++;
}
System.out.println(list);
}
}
这是我拥有的 LinkedList 文件:我正在使用虚拟头节点,它是一个循环单链表。
public class LinkedList{
private class Node{
private int pid;
private int time;
private Node next;
public Node(int pid, int time){
this.pid=pid;
this.time=time;
}
}//end Node
int size;
Node head;
public void add(int pid, int time) {
Node curr=head;
Node newNode=new Node(pid, time);
//empty list
if(head==null){
head=newNode;
newNode.next=head;
}//end if
else{
while(curr.next!=head){
curr=curr.next;
}//end while
curr.next=newNode;
newNode.next=head;
}//end else
size++;
}//end add
public void delete(Node curr){
if(size==0){
return;
}
else if(head==curr){
head=curr.next;
}
else{
Node prev=find(curr);
prev.next=curr.next;
}
size--;
}
public Node find(Node curr){
for(Node prev=head; prev.next!=curr; prev=prev.next){
return prev;
}
return curr;
}
public void sortList(){
Node position; // Position to fill...
Node start; // Where to start looking for the smallest...
if(size>=0){
for(position=head; position.next!=head; position=position.next){
Node smallest=position;
for(start=position.next; start!=head; start=start.next){
if (start.pid<smallest.pid){
smallest = start;
}//end if
}//end for
int tempPID=position.pid;
int tempTime=position.time;
position.pid=smallest.pid;
position.time=smallest.time;
smallest.pid=tempPID;
smallest.time=tempTime;
}//end for
}//end if
}//end sortList
public void timeSlice(int cpuTime){
for(Node curr=head; curr.next!=head; curr=curr.next){
curr.time=curr.time-cpuTime;
System.out.print("<" + curr.pid + ", " + curr.time +">" + " ");
//if the time remaining <= 0 then remove the node
if(curr.time<=0){
System.out.println("Process " + curr.pid + " has finished, and is now being terminated");
delete(curr);
}
}
}
public String toString(){
String s="";
for(Node curr=head; curr.next!=head; curr=curr.next)
s=s+"<"+curr.pid+", "+curr.time+"> ";
return s;
}
}
提前致谢,非常感谢。
最佳答案
首先,您没有像您所说的那样使用虚拟节点。如果列表仅包含单个节点,则它实际上永远不会被删除,因为 head.next
又只是 head
。这也会使列表处于不一致的状态,其中 size
为 0,但它仍然有一个节点。
find
将给出不正确的结果。您可能应该检测到这一点并抛出异常。
关于java - LinkedList打印和删除问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16137015/
我想添加 LinkedList (我们称之为列表 A)到 LinkedList> (称之为列表 B)。执行此操作后,我需要更改列表 A 的值并将其再次添加到列表 B,但不更改已存储在列表 B 中的值。
更新:感谢所有的回答。我发现的最干净的解决方案是这个: if ( k(Arrays.asList(new LinkedList<>())); 我有一个递归方法,可以从列表中生成所有“n 选 k”组合。
在我的 Java 应用程序中,以下两个都将编译和运行,并产生所需的结果。 //"Rotate" the list items one place to the left. myLinkedList.a
我写了一个LinkedList接受 Nodes 的类存储 Integers . 然后我创建了一个 LinkedList stack = new LinkedList() ,并添加了 Node s 如果
这个问题在这里已经有了答案: What does it mean to "program to an interface"? (33 个答案) 关闭 9 年前。 新手 Java 问题: 谁能解释一下
我有一个问题。我无法并排输出我的 LinkedList。我问了这个问题,但遗憾的是我的老师告诉我不要更改方法头或使用 java 库(如日历)。我得到了很多关于使用它或更改方法头的建议。我是根据年级而定
这里有什么问题?。我正在尝试使用邻接列表,通过利用 util 包中的集合来实现图形数据结构。这里 LinkedList array which holds some integer. Each ele
这个问题已经有答案了: Reversing a linked list in Java, recursively (33 个回答) 已关闭10 年前。 如何使用 linkedList 类中的方法以相反
我需要实现一个 LinkedList,到目前为止,我已经编写了在列表中按顺序插入值的方法。我有我的节点 front 作为我的类的实例数据,当创建我的第一个值并尝试将 front 的 next 值设置为
目前,我的 LinkedList(不是 Java 的)类中有一个方法,可以将单个节点添加到 LinkedList 中,如下所示: public void add(int index, T v) {
我正在编写一个读取 XML 文件的类,该 XML 使用“sax”类进行解析。在我的 XML 文件中,我创建了“for”标签和“宏”,使 for 循环能够写入 XML,例如: Th
我正在处理一个 C++ 作业,我将在一个链表的链表上创建一个搜索引擎。根据要求,我不能使用其他库和 STL。 基本上它会是这样的(我从小列表中删除了变量,因为它们是不相关的): 我的结构是这些: st
老实说,我现在真的很困惑这个问题,并且真的不知道如何解决这个问题。我需要编写一个方法,其中给定一个字符链接列表(例如:{'a','A','d','X'})并返回仅包含大写字符的列表(返回:{'A','
我正在尝试获取可执行文件中的两个链表,并在交替位置将它们合并到一起。前任。 ListOne 1,2,3 和 ListTwo 4,5 新的 ListOne 应该是 1,4,2,5,3。 链表.h文件:
这个问题在这里已经有了答案: Is List a subclass of List? Why are Java generics not implicitly polymorphic? (19 个回答
在尝试了解如何将哈希表插入LinkedLists时,我遇到了麻烦。我失去了尝试过的不同事物的数量。我知道我可以使用ArrayList或其他东西,但是我想使它与LinkedLists一起工作,以便可以对
我一直在尝试编写一种方法,不仅可以从 LinkedList(allUsers) 中删除对象(User),还可以从所有用户拥有的单个 LinkedList 中删除。谁能向我解释为什么这是错误的?我已经包
我有一个列表结构和一个名为树的递归函数。在下面的代码中,它永远不会到达 current == null 语句,因此它将永远运行。 如果我无法使用null,解决方案是什么? private void t
这个问题在这里已经有了答案: How does one add a LinkedList to a LinkedList in C#? (3 个答案) 关闭 9 年前。 假设我有以下内容: Link
我正在尝试为 LinkedList 创建一个反向 ListIterator,并且打算将其实现为 linkedList.listIterator(linkedList. size()) 交换了 next
我是一名优秀的程序员,十分优秀!