4月9号总结

java学习

一.steam流

1.介绍

Stream 是 Java 8 中引入的一种处理集合数据的新抽象。它提供了一种高效且便利的方式来处理集合中的元素,支持函数式编程的特性,使得集合操作变得更加简洁和灵活。

2.创建

List和Set可以直接调用接口的steam方法转换为流

复制代码
  List<String> s1= new ArrayList<>();
        s1.stream();

 Set<String> s=new HashSet<>();
        s.stream();

注意:map不能直接创建stream流,可以使用Map接口的keySet().stream()方法将Map的键集合转换为流,或使用values().stream()方法将Map的值集合转换为流。

复制代码
Stream<String> keyStream = map.keySet().stream();
Stream<Integer> valueStream = map.values().stream();
3.forerch(遍历)

在前面没有加限定操作的时候foreach可以遍历输出集合内的全部元素。

复制代码
public class test {
    public static void main(String[] args) {
        List<String> s1=new ArrayList<>();
        Collections.addAll(s1,"张三","李四","王五","猪八戒","孙悟空");
        s1.stream().forEach(System.out::println);

    }
}
4.filter(筛选)

fiter可以对我们流进行筛选,筛除不符合我们要求的元素,用上面的例子。

如果我们只需要保留名字长度为2的元素。

那么我们只需要保证元素.length()==2就行。

复制代码
List<String> s1=new ArrayList<>();
        Collections.addAll(s1,"张三","李四","王五","猪八戒","孙悟空");
        s1.stream().filter(s->s.length()==2).forEach(System.out::println);

我们还可以多次筛选,可以用多个filter或者用&&加多个条件。

复制代码
        List<String> s1=new ArrayList<>();
        Collections.addAll(s1,"张三","李四","王五","猪八戒","孙悟空");
        s1.stream().filter(s->s.length()==2&&s.startsWith("张") ).forEach(System.out::println);

    

        List<String> s1=new ArrayList<>();
        Collections.addAll(s1,"张三","李四","王五","猪八戒","孙悟空");
        s1.stream().filter(s->s.length()==2).filter(s->s.startsWith("张")).forEach(System.out::println);
5.sorted(流排序)

sorted可以将流按照从小到大排序。

复制代码
 List<String> s1=new ArrayList<>();
        Collections.addAll(s1,"cba","acb","bac","abc","cab");
        s1.stream().sorted().forEach(System.out::println);

这里先介绍部分,还有很多很方便的没有介绍。

二.蓝桥杯真题练习

1.接龙数列

样例输入

复制代码
5
11 121 22 12 2023

样例输出

复制代码
1

一道dp题,不看题解都想不到是dp题

复制代码
#include<iostream>
#define ll long long
using namespace std;
int main()
{
	ll n;
	cin>>n;
	ll dp[11]={0},ans=-1;//最长序列 
	for(int i=0;i<n;i++){
		string a;
		cin>>a;
		ll b=a.back()-'0',c=a[0]-'0';
		dp[b]=max(dp[b],dp[c]+1);
		ans=max(ans,dp[b]);
	}
	cout<<n-ans<<endl;//这里输出需要删除的个数 
	return 0;
}
2.冶炼金属

样例输入

复制代码
3
75 3
53 2
59 2

样例输出

复制代码
20 25

这里需要数学手算一下。

复制代码
#include<iostream>
#include<algorithm>

using namespace std;

int main() {
    int n;
    cin >> n;
    int mi = 0, mx = 1e9;
    while (n--) {
        int a, b;
        cin >> a >> b;
        mi = max(a / (b + 1) + 1, mi);
        mx = min(a / b, mx);
    }
    cout << mi << " " << mx << endl;
    return 0;
}
相关推荐
灯厂码农1 分钟前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
yoothey7 分钟前
报废审批流规则引擎设计——责任链模式完整实现
linux·开发语言·bash
geovindu23 分钟前
python: Functional Options Pattern
开发语言·后端·python·设计模式·惯用法模式·函数式选项模式
wuyk55530 分钟前
24. C 语言模块化:不是拆几个.c 文件那么简单
c语言·开发语言·stm32·单片机
四月天431 小时前
web安全-SSTI(服务器模板注入)
笔记·学习·web安全·网络安全
梦梦代码精1 小时前
电商系统不是技术堆叠:LikeShop如何用分层Hold住复杂业务?
java·docker·代码规范
凯瑟琳.奥古斯特1 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展
负责的蛋挞1 小时前
异步HttpModule的实现方式
java·服务器·前端
AC赳赳老秦1 小时前
防火墙规则批量配置实战:OpenClaw 自动生成模板、批量下发与合规性校验全解析
java·开发语言·人工智能·python·github·php·openclaw
☆cwlulu2 小时前
调试排查工具介绍(gdb、strace、Valgrind等)
开发语言·c++·嵌入式硬件·ubuntu