public class Leet { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.println("输入一个三位数:"); int i = scanner.nextInt(); int b = i / 100;//百位 int s = i % 100 / 10;//十位 int g = i % 10;//个位 System.out.print…
/** 题目:E - Leading and Trailing 链接:https://vjudge.net/contest/154246#problem/E 题意:求n^k得前三位数字以及后三位数字,保证一定至少存在六位. 思路:后三位求法只要不断对1000取余就行了. 前三位求法: 对一个数x,他可以用科学计数法表示为10^r*a (r为次方,1<=a<10) 设:n^k = x = 10^r*a 两边取对数: k*log10(n) = log10(x) = r+log10(a); 令y =…
import java.util.Scanner; /** * 功能:用位运算,判断一个数是否为2的n次方. * 思路:用1做移位操作,然后判断移位后的值是否与给定的数相同. */ public class Main3 { public boolean isPower(int n) { if (n < 1) { return false; } int m = 1; while (m < n) { m = m << 1; } if (m == n) { return true; }…
最近在看算法,看到这个题,觉得挺经典的,收起. 分析: 1 .把问题归结为图结构的遍历问题.实际上6个数字就是六个结点,把六个结点连接成无向连通图,对于每一个结点求这个图形的遍历路径,所有结点的遍历路径就是最后对这  6个数字的排列组合结果集.        2. 3,5不能相连:实际要求这个连通图的结点3,5之间不能连通, 可在构造图结构时就满足改条件,然后再遍历图.        3. 不能有重复: 考虑到有两个2,明显会存在重复结果,可以把结果集放在TreeSet中过滤重复结果     …
编写一个Java程序,计算一下1,2,…,9这9个数字可以组成多少个互不相同的.无重复数字的三位偶数. package com.hanqi; //编写一个Java程序,计算一下1,2,…,9 //这9个数字可以组成多少个互不相同的.无重复数字的三位偶数. public class Oushu { public static void main(String[] args) { int geshu = 0; for(int i =1; i <= 9; i++)//百位上的数字 { for(int…
title: Java生成前三位是字母循环的字典 date: 2018-08-17 18:52:22 tags: Java --- 最近要破解一个秘密,还好这个密码是有线索的,已知密码的前三位是三个字母,后五位是12345,所以干脆用代码生成字典的全部的可能. import java.io.File; import java.io.FileOutputStream; import java.io.OutputStream; public class createDic { public stat…
程序如下: import java.lang.StringBuffer; /** 给定一个浮点数,将其装换成人民币大写的读法 88.5:捌十捌元零伍角 */ public class Num2Rmb { private String[] hanArr={"零","壹","贰","叁","肆","伍","陆","柒","捌",&q…
转: [转]Java生成三位随机数 public class Test2 { public static void main(String [] srgs) { int i=(int)(Math.random()*900)+100; //int i= new java.util.Random().nextInt(900)+100;也可以System.out.println(i); } } 也就是要求100到999之间的随机数, Math.random()返回的是0到1之间的随机数,返回类型为do…
<script> function thousands(num){ var str = num.toString(); var reg = str.indexOf(".") > -1 ? /(\d)(?=(\d{3})+\.)/g : /(\d)(?=(?:\d{3})+$)/g; return str.replace(reg,"$1,"); } alert(thousands(1234567.1234567)); alert(thousands(…
调用这个Math.Random()函数能够返回带正号的double值,该值取值区间是[0.0,1.0),注意,它是左闭右开区间.返回值是一个伪随机选择的数,在该范围内(近似)均匀分布. 如果生成三位随机数,则参考如下代码: int i = (int)(Math.random()*900 + 100); String myStr = Integer.toString(i); System.out.println(myStr); 由于Math.Random()返回值的类型是double,所以在赋值给…