数据结构-怀化学院期末题(34)

题目描述:

请你定义一个链式线性表,可以对表进行"在某个位置之前插入一个元素"、"删除某个位置的元素"、"清除所有元素"、"获取某个位置的元素"、"修改某个位置的元素"等操作。键盘输入一些命令,可以执行上述操作。本题中,线性表元素为整数。

输入

各个命令以及相关数据,它们对应的格式如下:

在某个位置之前插入操作: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

代码:

java 复制代码
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;
            }
        }
    }
}
相关推荐
KpLn_HJL30 分钟前
leetcode - 2139. Minimum Moves to Reach Target Score
java·数据结构·leetcode
程序员老冯头2 小时前
第十五章 C++ 数组
开发语言·c++·算法
AC使者6 小时前
5820 丰富的周日生活
数据结构·算法
cwj&xyp7 小时前
Python(二)str、list、tuple、dict、set
前端·python·算法
无 证明7 小时前
new 分配空间;引用
数据结构·c++
xiaoshiguang311 小时前
LeetCode:222.完全二叉树节点的数量
算法·leetcode
爱吃西瓜的小菜鸡11 小时前
【C语言】判断回文
c语言·学习·算法
别NULL11 小时前
机试题——疯长的草
数据结构·c++·算法
TT哇11 小时前
*【每日一题 提高题】[蓝桥杯 2022 国 A] 选素数
java·算法·蓝桥杯
ZSYP-S12 小时前
Day 15:Spring 框架基础
java·开发语言·数据结构·后端·spring