数据结构-怀化学院期末题(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;
            }
        }
    }
}
相关推荐
Keep_Trying_Go22 分钟前
基于无监督backbone无需训练的类别无关目标统计CountingDINO算法详解
人工智能·python·算法·多模态·目标统计
有时间要学习36 分钟前
面试150——第三周
算法·面试
一车小面包43 分钟前
Neo4j中的APOC
算法·neo4j
H_BB1 小时前
前缀和算法详解
数据结构·算法
聆风吟º1 小时前
【数据结构手札】时间复杂度详解:概念 | 大O渐进表示法 | 习题
数据结构·算法·时间复杂度·大o渐进表示法
山楂树の2 小时前
买卖股票的最佳时机(动态规划)
算法·动态规划
好奇龙猫2 小时前
【大学院-筆記試験練習:线性代数和数据结构(1)】
数据结构·数学
小O的算法实验室3 小时前
2024年IEEE TMC SCI1区TOP,面向无人机辅助 MEC 系统的轨迹规划与任务卸载的双蚁群算法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
无才顽石3 小时前
什么是数学
算法·数理象
CoderCodingNo3 小时前
【GESP】C++五级真题(数论, 贪心思想考点) luogu-B4070 [GESP202412 五级] 奇妙数字
开发语言·c++·算法