`
jythoner
  • 浏览: 608027 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java每日一题05

阅读更多
每天只能把一篇文章发表到博客频道,为了能和更多的朋友分享Java每日一题,只好放弃将其他文章发表到博客频道的机会了:(大家可要支持我啊,呵呵

一个for语句循环10次产生10个100以内的随机数,要求数字不为0和不重复

重点是:1.如何产生随机数
        2.如何保持随机数不重复
package test18;

import java.util.Arrays;
import java.util.Random;

public class Test {
	public static void main(String[] args) {
		int i = 0, k = 0;
		int[] aa = new int[10];
		Random rand = new Random();
		for (i = 0; i < 10; i++) {
			aa[i] = rand.nextInt(100);
			for (k = 0; k < i; k++) {
				if (aa[i] == 0)
					aa[i] = rand.nextInt(100);
				if (aa[i] == aa[k])
					aa[i] = rand.nextInt(100);
			}
		}
		Arrays.sort(aa);
		for (int l = 0; l < aa.length; l++) {
			System.out.print(aa[l] + "\t");

		}
	}
}


或者

package test18;

import java.util.HashSet;
import java.util.Arrays;

public class RandomTest {
	public static void main(String[] args) {
		HashSet<Integer> hs = new HashSet<Integer>();
		while (hs.size() < 10) {
			int temp;
			temp = (int) (Math.random() * 100);
			if (temp != 0) {
				hs.add(temp);
			}
		}
		System.out.println("排序前");
		for (int i : hs) {
			System.out.print(i + " ");
		}
		System.out.println();
		System.out.println("排序后");
		Object[] array = hs.toArray();
		Arrays.sort(array);
		for (int i = 0; i < 10; i++) {
			System.out.print(array[i] + " ");
		}
	}
}
4
5
分享到:
评论
12 楼 nauhk 2010-04-01  
	
[align=center][/align]public static void main(String[] args) {
		int[] narry=new int[10];
		int index=0;
		String str=",";
		
		while(index<10){
			int n=(int)(100*Math.random());
			if(n!=0&&str.indexOf(","+n+",")<0){
				narry[index]=(int)n;
				str+=n+",";
				index++;
				System.out.println(str);
			}			
		}

	}
11 楼 dapp66 2009-03-05  
还是没解决重复元素的问题。
10 楼 唯美古典 2009-02-25  
[flash=200,200][flash=200,200][/flashfor (k = 0; k < i; k++) {  
    if (aa[i] == 0)  
        aa[i] = rand.nextInt(100);  
    if (aa[i] == aa[k])  
        aa[i] = rand.nextInt(100);[/flash]  
}
9 楼 唯美古典 2009-02-25  
[/codefor (k = 0; k < i; k++) {  
    if (aa[i] == 0)  
        aa[i] = rand.nextInt(100);  
    if (aa[i] == aa[k])  
        aa[i] = rand.nextInt(100);  
}
8 楼 唯美古典 2009-02-25  
import java.util.Scanner; 
 
public class StringOprate { 
 
    /**
     * @param args
     */ 
    public static void main(String[] args) { 
        // TODO Auto-generated method stub 
        while (true) { 
            Scanner scanner = new Scanner(System.in); 
            String temp = scanner.nextLine(); 
            /*
             * for (int i = temp.length() - 1; i >= 0; i--) {
             * System.out.print(temp.charAt(i)); }
             */ 
            StringBuilder s1 = new StringBuilder(temp); 
            // StringBuffer s1 = new StringBuffer(temp); 
            System.out.println(s1.reverse()); 
            System.out.println(); 
            if (temp.equals("exit")) { 
                break; 
            } 
        } 
    } 
}
7 楼 suko 2009-02-24  
public static void main(String[] args) {
Random random = new Random();
List list = new LinkedList();
int size = list.size();
int temp = 0;
while(size < 10) {
temp = random.nextInt(100);
if(temp == 0 || list.contains(temp)) {
continue;
}
list.add(temp);
size = list.size();
}
for(int i = 0; i < list.size(); i++) {
System.out.println(list.get(i)+" ");
}
}
6 楼 helloworld365 2009-02-17  
第一个方法确实有问题,这是我打印出来的
0
5
18
20
26
39
44
48
54
85
出现0了
5 楼 kakaluyi 2009-02-13  
第一种方法是有问题,同lt0604 ,重新生成随机数,k需要归0
4 楼 dandy 2009-02-11  
lt0604 写道

第一个方案是有问题的,
jythoner 写道



Java代码

for&nbsp;(k&nbsp;=&nbsp;0;&nbsp;k&nbsp;&lt;&nbsp;i;&nbsp;k++)&nbsp;{&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(aa[i]&nbsp;==&nbsp;0)&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;aa[i]&nbsp;=&nbsp;rand.nextInt(100);&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(aa[i]&nbsp;==&nbsp;aa[k])&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;aa[i]&nbsp;=&nbsp;rand.nextInt(100);&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;
}&nbsp;&nbsp;for (k = 0; k &lt; i; k++) {  
    if (aa[i] == 0)  
        aa[i] = rand.nextInt(100);  
    if (aa[i] == aa[k])  
        aa[i] = rand.nextInt(100);  
}
并不能保证随机数不为0和不重复,只要重新随机过就要再重aa[]为0重新比较

第一个方案没什么问题,他用的是双循环。
3 楼 lt0604 2009-02-10  
第一个方案是有问题的,
jythoner 写道

for (k = 0; k < i; k++) {   
    if (aa[i] == 0)   
        aa[i] = rand.nextInt(100);   
    if (aa[i] == aa[k])   
        aa[i] = rand.nextInt(100);   
}


并不能保证随机数不为0和不重复,只要重新随机过就要再重aa[]为0重新比较
2 楼 dandy 2009-02-09  
顶下~~~~~
1 楼 dandy 2009-02-09  
首先想到了第一个方法,呵呵!第二个倒是没想到。

相关推荐

    JAVA每日一题20

    【标题】"JAVA每日一题20"是一个关于Java编程的挑战题目,旨在提升开发者对Java语言的理解和应用能力。通常这类题目会涉及到Java的核心概念、语法特性或者常见问题的解决策略。 【描述】虽然描述部分为空,但根据...

    Java每日一题20160906

    Java每日一题20160906,每日一道Java编程题,提高自己

    JAVA每日一题11

    【标题】"JAVA每日一题11"是一个关于Java编程的日常练习问题,可能是从某个技术社区或博客中提取的。通常,这类题目旨在帮助开发者巩固基础,提升技能,或者探讨一些特定的Java编程概念。从提供的信息来看,我们无法...

    Java每日一题24(最后一题)

    NULL 博文链接:https://jythoner.iteye.com/blog/344407

    JAVA每日一题08

    标题“JAVA每日一题08”暗示我们今天将探讨与Java编程语言相关的技术问题,可能是某个挑战或难题的解决方案。由于没有提供具体的题目内容,我们可以从更广泛的Java知识角度出发,结合“源码”和“工具”这两个标签来...

    java每日一练练习

    根据给定的信息,我们可以归纳出以下几个关键的Java知识点: ### 1. 在屏幕上输出文本 ...这些练习题覆盖了Java语言的基础语法、控制结构以及面向对象编程的基本概念,非常适合初学者进行日常练习。

    每日一题20190628_java面试题_

    【标题】:“每日一题20190628_java面试题_”是指一个针对Java程序员的面试问题集合,可能包含各种Java编程语言、框架、设计模式以及系统架构等相关问题,旨在帮助求职者准备面试。 【描述】:“java面试题,参考...

    Java面试题-每日一题:String、StringBuffer、StringBuilder的区别

    Java面试题-每日一题:String、StringBuffer、StringBuilder的区别

    每日一题Java方向编程题答案day011

    在给定的编程题中,我们需要判断一个字符串是否为回文串。回文串是指正读反读都一样的字符串,例如"madam"或"level"。Java中,我们可以利用String类提供的方法来实现回文串的判断。解题思路是使用两个指针,一个从...

    每日一题Java方向选择题答案day011

    题目中给出了一个类A及其成员变量和方法的定义,询问了哪些调用是错误的,这涉及到对Java成员访问规则的理解。 以上知识点涵盖了Java多线程、序列化、面向对象设计、变量存储、类型转换、运算符优先级、方法存储、...

    Java方向每日一题day17_11月24日编程题答案1

    "Java方向每日一题day17_11月24日编程题答案1" 在本题中,我们需要解决一个火车进站的问题,给定n辆火车的编号,要求计算出所有可能的出站顺序。该问题可以使用栈来解决,因为栈的出栈顺序满足后进先出(Last In ...

    java方向每日一题day17_11月24日选择题答案1

    在题目中,有几道关于Java语言特性和语法的单选题: 1. 类实例化语句的正确选项是D。 2. 描述错误的Java语言特点选项是C,因为Java是面向对象的语言,而非面向过程。 3. 编译并运行给定的代码`public class Pvf{ ...

    基于LeetCode每日一题的Java编程语言设计源码分享

    本项目为LeetCode每日一题的Java编程语言解答源码,总计包含223个文件,包括202个Java源文件、7个Markdown文件、6个JSON文件、4个JAR包文件以及少量其他类型文件。这些源码旨在帮助开发者通过实践解决LeetCode上的...

    Java方向每日一题day18_11月25日编程题答案1

    【Java编程题解析】 在Java编程中,我们经常会遇到各种挑战性的题目,旨在提升我们的编程能力和算法思维。这里有两个不同的编程题目,让我们一一解析。 ### 题目1:DNA序列链接 - 找到GC比例最大的子串 #### 题目...

    Java方向每日一题day18_11月25日选择题答案1

    Java是一种面向对象的编程语言,其核心特性之一就是封装,这是OOP(面向对象编程)的三大特性之一,另外两个是继承和多态。封装的主要目的是保护数据的安全性,通过限制对类内部成员的直接访问,防止外部代码随意...

    java互联网面试题整理

    整理互联网常见面试题,为春招、校招和社招做准备。如若不能下载,关注公众号“每日技术分享”,可免费下载资源。

    2020年java常见面试题汇总%28附答案%29.pdf

    干货资源推荐: JVM干货调试视频教程分享 50份优秀Java求职者简历 SpringCloud前后端分离实战项目...本资源整理自互联网,仅供学习交流使用,请勿商用,坚持每日分享一套Java学习资源干货,一起提高,一起进步!!!

    leetcode每日一题总结.zip

    LeetCode的每日一题是平台上的一个特色功能,每天会发布一个新的编程题目,涵盖各种难度级别,从基础到进阶,涉及语言包括Java、Python、C++等。这些题目涵盖了数据结构(如数组、链表、栈、队列、树、图等)和算法...

    java面试题大全-葵花宝典 - 图形图像 - 道客巴巴

    【Java面试题大全-图形图像篇】 在Java面试中,图形图像处理是一个常见的技术领域,涉及到Java AWT(Abstract Window Toolkit)和Swing组件库,以及更高级的JavaFX。这些框架提供了创建用户界面和图形内容的能力。...

    leetcode-java:每日一题leetcode-java版

    本项目"leetcode-java:每日一题leetcode-java版"是针对LeetCode平台的Java解决方案集,旨在帮助Java开发者通过每日解决一个LeetCode题目来提高他们的算法理解和编程能力。 在Java编程语言中,解决问题的关键在于...

Global site tag (gtag.js) - Google Analytics