题目描述:
请你定义一个链式线性表,可以对表进行“在某个位置之前插入一个元素”、“删除某个位置的元素”、“清除所有元素”、“获取某个位置的元素”、“修改某个位置的元素”等操作。键盘输入一些命令,可以执行上述操作。本题中,线性表元素为整数。
输入
各个命令以及相关数据,它们对应的格式如下:
在某个位置之前插入操作:insert,接下来的一行是插入的组数n,下面是n行数据,每行数据有两个值,分别代表位置与插入的元素值
清除线性表:clear
获取某个位置的元素:getelem,接下来一行是需要获取的元素位置
删除某个位置的元素:delete,接下来一行是被删除的元素位置
修改某个位置的元素:update,接下来一行是被修改的元素位置及值
打印所有元素:getallelem
当输入的命令为exit时,程序结束
输出
当输入的命令为getelem时,请输出获取的元素值,
当输入的命令是delete时,请输出被删除的那个元素值
当输入的命令是getallelem时,请输出所有元素值
注意,每一个命令对应一行输出,如果一行有多个元素,则元素之间用空格隔开。
样例输入:
insert
2
1 1
2 2
update
2 5
getallelem
delete
1
getallelem
clear
insert
2
1 3
2 4
getelem
2
exit
样例输出:
1 5
1
5
4文章来源:https://www.toymoban.com/news/detail-815643.html
代码:文章来源地址https://www.toymoban.com/news/detail-815643.html
import java.util.Scanner;
public class no34 {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int a[] = new int[1024];
int c[] = new int[1024];
int len = 0;
while (true){
String s = in.next();
if(s.equals("getelem")){
int b = in.nextInt();
System.out.println(a[b]);
}
if(s.equals("insert")){
int b = in.nextInt();
for(int i = 0;i < b;i ++){
int x = in.nextInt();
int y = in.nextInt();
for(int j = len;j >= x;j --){
a[j+1] = a[j];
}
len ++;
a[x] = y;
}
}
if(s.equals("clear")){
a = c;
len = 0;
}
if(s.equals("delete")){
int b = in.nextInt();
System.out.println(a[b]);
for(int j = b;j < len;j ++){
a[j] = a[j+1];
}
len --;
}
if(s.equals("update")){
int x = in.nextInt();
int y = in.nextInt();
a[x] = y;
}
if(s.equals("getallelem")){
for(int i = 1;i <= len;i ++){
System.out.printf("%d ",a[i]);
}
System.out.println();
}
if(s.equals("exit")){
break;
}
}
}
}
到了这里,关于数据结构-怀化学院期末题(34)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!