第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10;

  分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判断生成的字符串是否包含重复,在判断长度是不是10,等等.

     *2.其实这题我们可以培养一个习惯,大问题分解小问题解决.

(1).10个字符串,我们先产生一个10个字符不重复的字符串,

       (2).怎么去重复呢?集合中的HashSet就可以,这题不适合用包含方法做,代码复杂

       (3).字符组成是由(a-zA-Z0-9)  难道我们在随机他们的码表一一判断吗?-------->可以把们放到一个容器中ArrayList 在集合的随机索引

    第一步:先搞一个集合存储要随机的数据

    

    public static ArrayList<Character> getContainer(){
//建立一个容器存放
ArrayList<Character> array = new ArrayList<>();
//通过for循环一一存储到集合中
for (char i = 'a'; i <='z'; i++) {
array.add(i);
}
for (char i = 'A'; i <='Z'; i++) {
array.add(i);
}
for (char i = '0'; i <='9'; i++) {
array.add(i);
}
return array;
}

      第二步:产生一个字符串,其字符不相同

    

public static String getRandomString(ArrayList<Character> arrayList){
//用hashset接收字符 这样就不会产生重复
HashSet<Character> characters = new HashSet<>();
//字符串长度为10
while(characters.size()<10){
//在字符容器中随机拿字符 先随机索引
int index = (int) (Math.random()*arrayList.size());
//添加到hashset集合中
characters.add(arrayList.get(index));
} //遍历hashset集合 连接成字符串
String string="";
for (Character character : characters) {
//""加字符 转换成字符串这是基础语法,不知道的同学要研究一个基础语法了
string+=character;
}
//返回字符串
return string;
}

第三步:和第一步一样了,调用N次第二步方法,10个不重复字符串就好了

public static ArrayList<String> getRandomStrings(ArrayList<Character> arrayList){
//建立HashSet集合接收 去掉重复
HashSet<String> hashSet = new HashSet<>();
while(hashSet.size()<10){
hashSet.add(getRandomString(arrayList));
}
ArrayList<String> list = new ArrayList<>();
//将Hashset集合中的元素全部添加到list集合中
list.addAll(hashSet);
return list;
}

最后mian方法调用

public static void main(String[] args) {
ArrayList<Character> arrayList = getContainer();
ArrayList<String> arrayList2 = getRandomStrings(arrayList);
//遍历
for (String string : arrayList2) {
System.out.println(string);
}
}

第二题:我们玩一个随机0-9组成一个8位不重复数字的字符串.产生4个这样的字符串,也是互相不重复的

分析:*1.我们先产生一个0-9组成的字符串

    (1).第一种方式:hashSet

    (2):第二种方式:StringBulider  想想这个怎么用

   *2.在产生多个

1.产生一个字符串

    public static String getRandomString(){
//HashSet存储不重复的数
HashSet<Character> characters = new HashSet<>();
//长度为8
while(characters.size()<8){
//这个只要随机0-9就好了
int number = (int) (Math.random()*9);
//强制类型转换
char ch = (char)number;
characters.add(ch);
} String string="";
for (Character character : characters) {
string+=character;
}
return string;
}

第二种方式用StringBuilder做

public static String getRandomStringBulider(){
//先定一个StringBulider
StringBuilder builder = new StringBuilder();
//也是一样判断长度位8 停止循环
while(builder.length()<8){
//产生随机数
int number = (int) (Math.random()*9);
//StringBuilder中没有包含的方法 我们可以转成String做--> builder.toString()
if(!builder.toString().contains(number+"")){
builder.append(number);
}
}
return builder.toString();
}

2.4个不重复的字符串

public static HashSet<String> getRandomStrings(){
//HashSet存储不重复的字符串
HashSet<String> hashSet =new HashSet<>();
while(hashSet.size()<4){
hashSet.add(getRandomStringBulider());
}
return hashSet;
}

最后 main方法调用,这里我们加一个玩法用map集合玩一个超市货物的编号与品名对应

public static void main(String[] args) {
String[] str = {"可乐","啤酒","烤鸭","苍老师"};
Map<String, String> map =new LinkedHashMap<String, String>();
//怎么把刚在获取的编号 和 商品对应呢
//遍历 hashSet 没有索引 我们用List集合
HashSet<String> hashSet =getRandomStrings();
ArrayList<String> arrayList = new ArrayList<>();
arrayList.addAll(hashSet);
//遍历添加
for (int i = 0; i < str.length; i++) {
map.put(arrayList.get(i), str[i]);
} //遍历Map集合
for (String string : map.keySet()) {
System.out.println(string+" : "+map.get(string));
} }

今天就到这里了.....写的不好,请大家给我点建议

java基础集合经典训练题的更多相关文章

  1. JAVA基础-集合(二)

    一.Map整体结构体系 Map是集合的另一大派系,与Collection派系不同的是Map集合是以键值对儿的形式存储在集合的.两个键为映射关系,其中第一个键为主键(主键是唯一的不可重复),第二个键为v ...

  2. Java基础-集合的嵌套

    Java基础-集合的嵌套 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.静态导入 静态导入是在JDK1.5后的新特性,可以减少开发的代码量,但是实际用处是很一般,静态导入的标准 ...

  3. Java基础算法集50题

    最近因为要准备实习,还有一个蓝桥杯的编程比赛,所以准备加强一下算法这块,然后百度了一下java基础算法,看到的都是那50套题,那就花了差不多三个晚自习的时间吧,大体看了一遍,做了其中的27道题,有一些 ...

  4. Java基础——集合框架

    Java的集合框架是Java中很重要的一环,Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型.Java平台的完整集合框架如下图所示: 上 ...

  5. java基础50道编程题

    50道JAVA基础编程练习题 [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子对数为多少? 程序分析 ...

  6. java基础---集合(1)

    一. 基本概念 集合.数组都是对多个数据进行存储操作的结构,简称Java容器 数组:长度确定,类型确定,对于添加.删除.插入等操作效率不高,元素有序可重复 Java中集合框架顶层框架是:java.ut ...

  7. Java基础——集合源码解析 List List 接口

    今天我们来学习集合的第一大体系 List. List 是一个接口,定义了一组元素是有序的.可重复的集合. List 继承自 Collection,较之 Collection,List 还添加了以下操作 ...

  8. Java基础—集合

    一.概述 Java中的集合框架主要分为两大派别:Collection 和 Map —— 位于util包下 类的基础关系图如下(图片来自百度) 常用: List——有序可重复 Set——无序不可重复 M ...

  9. java基础集合简介Set(三)中

    今天主要说夏set集合,每天抽出一个小时总结下,生活会更加美好! --< java.util >-- Set接口: 数据结构:数据的存储方式: Set接口中的方法和Collection中方 ...

随机推荐

  1. 利用snowfall.jquery.js实现爱心满屏飞

    小颖在上一篇一步一步教你用CSS画爱心中已经分享一种画爱心的方法,这次再分享一种方法用css画爱心,并利用snowfall.jquery.js实现爱心满屏飞的效果. 第一步: 利用伪元素before和 ...

  2. 渗透测试工具BurpSuite做网站的安全测试(基础版)

    渗透测试工具BurpSuite做网站的安全测试(基础版) 版权声明:本文为博主原创文章,未经博主允许不得转载. 学习网址: https://t0data.gitbooks.io/burpsuite/c ...

  3. WCF学习之旅—第三个示例之四(三十)

           上接WCF学习之旅—第三个示例之一(二十七)               WCF学习之旅—第三个示例之二(二十八)              WCF学习之旅—第三个示例之三(二十九)   ...

  4. Ngrok让你的本地Web应用暴露在公网上

    1.Ngrok介绍 Ngrok是一个反向代理,通过在公共的端点和本地运行的Web服务器之间建立一个安全的通道.Ngrok可捕获和分析所有通道上的流量,便于后期分析和重放.简单来说,利用 Ngrok可以 ...

  5. [Egret]优雅的写http

    首先,自从使用链式调用的写法后,就一发不可收拾的喜爱上了这种优雅的方式.不管是写架构还是写模块,我都会不自觉的使用这种最优雅的方式.链式写法既减少了代码量,又非常优雅的. 在使用 egret 的htt ...

  6. [原] KVM虚拟机网络闪断分析

    背景 公司云平台的机器时常会发生网络闪断,通常在10s-100s之间. 异常情况 VM出现问题时,表现出来的情况是外部监控系统无法访问,猜测可能是由于系统假死,OVS链路问题等等.但是在出现网络问题的 ...

  7. 【架构设计】分布式文件系统 FastDFS的原理和安装使用

    本文地址 分享提纲: 1.概述 2. 原理 3. 安装 4. 使用 5. 参考文档 1. 概述 1.1)[常见文件系统] Google了一下,流行的开源分布式文件系统有很多,介绍如下:   -- mo ...

  8. PHP 设计模式概述

    一.设计模式(Design pattern)是什么? 设计模式是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. ...

  9. 为什么很多SaaS企业级产品都熬不过第一年

    因工作缘由,笔者与周边数位SaaS企业级应用的创始人.运营负责人有过深入接触,发现一个有趣的现象:刚起步时,蓝图远志.规划清晰,但是一路下来,却异常艰难,有些甚至熬不过第一年,就关门歇业. 2015年 ...

  10. android手机登录时遇到“QQ安全登录发现病毒”解决

    android手机作为开源系统非常容易感染病毒,有时候我们会经常遇到手机QQ登录时检测到app被感染,一般情况是由手机感染病毒所引起的,安装腾讯管家后只能检测病毒和卸载感染病毒的软件,不能清除病毒.解 ...