2022蓝桥杯大赛软件类国赛Java大学B组 左移右移 空间换时间+双指针

简介: 2022蓝桥杯大赛软件类国赛Java大学B组 左移右移 空间换时间+双指针


 
 
import java.util.Scanner;
 
public class Main {
   static Scanner sc=new Scanner(System.in);
   public static void main(String[] args) {
      
    int n=sc.nextInt();//数组长度
    int t=sc.nextInt();//操作次数
    int arr[]=new int[n];
    char arr1[] = new char[t];
    int  arr2[] = new int[t];
    int visited[]=new int[n+1];
    
    for(int i = 0 ;i<t ; i++) {
      arr1[i]=sc.next().charAt(0);
      arr2[i]=sc.nextInt();
    }
    
    //双指针
    int i=0;
    int j=n-1;
    
    for(int temp=t-1;temp>=0;temp--) {
      if(visited[arr2[temp]]==-1)continue;
      if(arr1[temp]=='R') {
        arr[j]=arr2[temp];
        j--;
        visited[arr2[temp]]=-1;
      }
      if(arr1[temp]=='L') {
        arr[i]=arr2[temp];
        i++;
        visited[arr2[temp]]=-1;
      }
    }
    int p=1;
    for(int b=0;b<n;b++) {
      if(arr[b]==0) {
        while(visited[p]==-1) {
          p++;
        }
        visited[p]=-1;
        System.out.print(p+" ");
      }
      else System.out.print(arr[b]+" ");
    }
   } 
}
目录
相关文章
|
1月前
|
Java 开发者
在 Java 中,一个类可以实现多个接口吗?
这是 Java 面向对象编程的一个重要特性,它提供了极大的灵活性和扩展性。
153 57
|
7天前
|
JSON Java Apache
Java基础-常用API-Object类
继承是面向对象编程的重要特性,允许从已有类派生新类。Java采用单继承机制,默认所有类继承自Object类。Object类提供了多个常用方法,如`clone()`用于复制对象,`equals()`判断对象是否相等,`hashCode()`计算哈希码,`toString()`返回对象的字符串表示,`wait()`、`notify()`和`notifyAll()`用于线程同步,`finalize()`在对象被垃圾回收时调用。掌握这些方法有助于更好地理解和使用Java中的对象行为。
|
1月前
|
存储 缓存 安全
java 中操作字符串都有哪些类,它们之间有什么区别
Java中操作字符串的类主要有String、StringBuilder和StringBuffer。String是不可变的,每次操作都会生成新对象;StringBuilder和StringBuffer都是可变的,但StringBuilder是非线程安全的,而StringBuffer是线程安全的,因此性能略低。
57 8
|
1月前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
74 17
|
1月前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
1月前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
135 4
|
1月前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
80 2
|
1月前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
62 4
|
1月前
|
存储 Java 编译器
java wrapper是什么类
【10月更文挑战第16天】
42 3
|
1月前
|
Java Android开发
Eclipse 创建 Java 类
Eclipse 创建 Java 类
29 0