数据结构-怀化学院期末题(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;
            }
        }
    }
}
相关推荐
To_OC4 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵8 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC10 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
刘马想放假2 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安2 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法