第一题:要求产生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. SQL Server 数据加密功能解析

    SQL Server 数据加密功能解析 转载自: 腾云阁 https://www.qcloud.com/community/article/194 数据加密是数据库被破解.物理介质被盗.备份被窃取的最 ...

  2. 终于等到你:CYQ.Data V5系列 (ORM数据层)最新版本开源了

    前言: 不要问我框架为什么从收费授权转到免费开源,人生没有那么多为什么,这些年我开源的东西并不少,虽然这个是最核心的,看淡了就也没什么了. 群里的网友:太平说: 记得一年前你开源另一个项目的时候我就说 ...

  3. MVVM模式解析和在WPF中的实现(六) 用依赖注入的方式配置ViewModel并注册消息

    MVVM模式解析和在WPF中的实现(六) 用依赖注入的方式配置ViewModel并注册消息 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二 ...

  4. 工欲善其事,必先利其器 之 VS2013全攻略(安装,技巧,快捷键,插件)!

    如有需要WPF工具的朋友可以移步 工欲善其事,必先利其器 之 WPF篇: 随着开发轨迹来看高效WPF开发的工具和技巧 之前一篇<c++的性能, c#的产能?!鱼和熊掌可以兼得,.NET NATI ...

  5. HTML DOM 对象

    本篇主要介绍HTML DOM 对象:Document.Element.Attr.Event等4个对象. 目录 1. Document 对象:表示文档树的根节点,大部分属性和方法都是对元素进行操作. 2 ...

  6. 【uwp】浅谈China Daily 中划词翻译的实现

    学习uwp开发也有一段时间了,最近上架了一个小应用(China Daily),现在准备将开发中所学到的一些东西拿出来跟大家分享交流一下. 先给出应用的下载链接:China Daily , 感兴趣的童鞋 ...

  7. WebLogic的安装和配置以及MyEclipse中配置WebLogic

    WebLogic 中间件: 是基础软件的一大类,属于可复用软件的范畴,顾名思义,中间件属于操作系统软件与应用软件的中间,比如:JDK,框架,weblogic. weblogic与tomcat区别 : ...

  8. SpringMVC+Shiro权限管理【转】

    1.权限的简单描述 2.实例表结构及内容及POJO 3.Shiro-pom.xml 4.Shiro-web.xml 5.Shiro-MyShiro-权限认证,登录认证层 6.Shiro-applica ...

  9. Android中常见的图片加载框架

    图片加载涉及到图片的缓存.图片的处理.图片的显示等.而随着市面上手机设备的硬件水平飞速发展,对图片的显示要求越来越高,稍微处理不好就会造成内存溢出等问题.很多软件厂家的通用做法就是借用第三方的框架进行 ...

  10. SSH免手动输入密码和设置代理

    通过使用sshpass将密码写入命令里,直接执行,免去手动密码输入的步骤命令如下: sshpass -p password_abc ssh user_abc@ssh_host -p ssh_port ...