数据结构-怀化学院期末题(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;
            }
        }
    }
}
相关推荐
草履虫建模37 分钟前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq3 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq3 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq4 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)4 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi5 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱5 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头5 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头5 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱7 小时前
IP校验和算法解析与实现
网络·tcp/ip·算法