java算法大礼包

2024-06-11 20:20
文章标签 java 算法 大礼包

本文主要是介绍java算法大礼包,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1.读取数据
  • 2.字符串相关处理
  • 3.JAVA答题通用框架
  • JAVA输出格式问题
  • 排序题
  • [GESP202403 五级] 成绩排序
    • 题目描述
    • 输入格式
    • 输出格式
    • 样例 #1
      • 样例输入 #1
      • 样例输出 #1
    • 提示

1.读取数据

1.1不停的读取数据同时处理
注意:hasNext()方法会阻塞式的检测有没有下一个数据,在他的内部会不停的循环检测

public boolean hasNext() {ensureOpen();saveState();modCount++;while (!sourceClosed) {     //数据源没有关闭就一直循环if (hasTokenInBuffer()) {    //直到缓存区中有数据才会返回,不然就会一直循环等待return revertState(true);}readInput();}boolean result = hasTokenInBuffer();return revertState(result);}
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);while (in.hasNext()) {int a = in.nextInt();int b = in.nextInt();int c = a + b;System.out.println(c);}}
}

1.2读取一行的数据
c语言网1003

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);String s = in.nextLine();     //这里返回的是Stringfor(int i = 0;i<s.length();i++){char ch = s.charAt(i);if(ch>='a' && ch<='u' || ch>='A' && ch<='U'){ch=(char)(ch+4);}if(ch>='w' && ch<='z' || ch >='W'&& ch<='Z'){ch = (char)(ch + 4 - 26);    //假设z后面的四个数是x1,x2,x3,x4 将x1,x2,x3,x4-26转为a,b,c,d}System.out.print(ch);}}
}

2.字符串相关处理

String相关

String s = new String("Hello,World")
String s = "Hello,World"   //String专属,不用构造器
String.charAt(i);         //获取String第i个位置的元素值

StringBuilder相关

StringBuilder sb = new StringBuilder();
StringBuilder sb = new StringBuilder("Hello");StrBuilder sb = new StrBuilder();int i = 3;sb.append('a');    //添加元素sb.append('b');sb.append('c');sb.append('d');sb.charAt(3);       //查看某位置元素sb.setCharAt(3,'a');    //修改某位置元素System.out.println(sb);

3.JAVA答题通用框架

//导入类public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);//这里输入程序逻辑
}

JAVA输出格式问题

System.out.printf("%8d ",num);     //冒充c语言

排序题

题1.

[GESP202403 五级] 成绩排序

题目描述

n n n 名同学,每名同学有语文、数学、英语三科成绩,你需要按照如下规则对所有同学的成绩从高到低排序:

  1. 比较总分,高者靠前;
  2. 如果总分相同,则比较语文和数学两科的总分,高者靠前;
  3. 如果仍相同,则比较语文和数学两科的最高分,高者靠前;
  4. 如果仍相同,则二人并列。

你需要输出每位同学的排名,如遇 x x x 人并列,则他们排名相同,并留空后面的 x − 1 x - 1 x1 个名次。例如,有 3 3 3 名同学并列第 1 1 1,则后一名同学自动成为第 4 4 4 名。

输入格式

第一行一个整数 N N N,表示同学的人数。
接下来 N N N 行,每行三个非负整数 c i , m i , e i c_i, m_i, e_i ci,mi,ei 分别表示该名同学的语文、数学、英语成绩。

输出格式

输出 N N N 行,按输入同学的顺序,输出他们的排名。
注意:请不要按排名输出同学的序号,而是按同学的顺序输出他们各自的排名。

样例 #1

样例输入 #1

6
140 140 150
140 149 140
148 141 140
141 148 140
145 145 139
0 0 0

样例输出 #1

1
3
4
4
2
6

提示

  • 30 % 30\% 30% 的数据, N ≤ 100 N \leq 100 N100,且所有同学总分各不相同。
  • 对全部的测试数据,保证 2 ≤ N ≤ 1 0 4 2 \leq N \leq 10^4 2N104 0 ≤ c i , m i , e i ≤ 150 0 \leq c_i, m_i, e_i \leq 150 0ci,mi,ei150

这篇关于java算法大礼包的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1052191

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第