D算法java代码 java算法总结

求JAVA算法:这里有A,B,C,D,E五个字符串,求出五个字符串的所有任意组合(五个字符串可以不同时出现)有些人的用复制数列D算法java代码,算法低效、粗野浪费 。
给D算法java代码你个、 高效、简洁而且泛型通用的全组合D算法java代码:
public class Test{
public staticvoid main(String[] args) {
String[] a = { "A", "B", "C", "D", "E" };
for(int i=1;i=a.length;i){
System.out.println(a.length "选" i);
String[] res=new String[i];
combine(a,0,res,0);
}
}
final static public void combine(final Object a[], final int a_pos,final Object rs[], final int rs_pos)
{
if(rs_pos=rs.length){
for(int i=0;irs.length;i) System.out.print(rs[i] " ");
System.out.println();
}else for(int ap=a_pos; apa.length; ap){
rs[rs_pos]=a[ap]; combine(a,ap 1,rs,rs_pos 1);
}
}
}
=======
5选1
A
B
C
D
E
5选2
A B
A C
A D
A E
B C
B D
B E
C D
C E
D E
5选3
A B C
A B D
A B E
A C D
A C E
A D E
B C D
B C E
B D E
C D E
5选4
A B C D
A B C E
A B D E
A C D E
B C D E
5选5
A B C D E
java十进制转二进制代码怎么解决?下面是根据十进制数转二进制数D算法java代码的算法所写的一段Java程序示例代码:
import java.math.BigDecimal;
public class Test {
public static void main(String[] args) {
Test t = new Test();
double d = 8;
String s = t.decimal2BinaryStr(d);
System.out.println("十进制数" d "转成二进制数为:" s);
}
/**
* 十进制数转二进制数
* @param d 十进制数
* @return 十进制数转换成二进制的字符串
*/
public String decimal2BinaryStr(double d){
String result = decimal2BinaryStr_Inte(d);
result= decimal2BinaryStr_Deci(d);
return result;
}
/**
* 十进制整数部分转二进制数
【D算法java代码 java算法总结】* @param d 十进制数
* @return 十进制整数部分转换成二进制的字符串
*/
public String decimal2BinaryStr_Inte(double d){
//return Integer.toBinaryString((int)d);
/*
* 本来利用上面的Integer.toBinaryString(int)就可以得到整数部分的二进制结果D算法java代码,
* 但为D算法java代码了展示十进制转二进制的算法D算法java代码,现选择以下程序来进行转换
*/
String result = "";
long inte = (long)d;
int index = 0;
while(true){
result= inte%2;
inte = inte/2;
index;
if(index%4 == 0){
result =" ";
}
if(inte==0){
while(index%4!=0){
result ="0";
index;
}
break;
}
}
char[] c = result.toCharArray();
char[] cc = new char[c.length];
for(int i=c.length; i0; i--){
cc[cc.length-i] = c[i-1];
}
return new String(cc);
}
/**
* 十进制小数部分转二进制
* @param d 十进制数
* @return 十进制小数部分转换成二进制小数的字符串
*/
public String decimal2BinaryStr_Deci(double d){
return decimal2BinaryStr_Deci(d, 0);
}
/**
* 十进制小数部分转二进制
* @param d 十进制数
* @param scale 小数部分精确的位数
* @return 十进制小数部分转换成二进制小数的字符串
*/
public String decimal2BinaryStr_Deci(double d, int scale){
double deci = sub(d,(long)d);
if(deci==0){
return "";
}
//为D算法java代码了防止程序因所转换的数据转换后的结果是一个无限循环的二进制小数,因此给其一个默认的精确度
if(scale==0){
scale = (String.valueOf(deci).length()-2)*4;
}
int index = 0;
StringBuilder inteStr = new StringBuilder();
double tempD = 0.d;
while(true){
if(deci==0 || index==scale){
while(index%4!=0){
inteStr.append("0");
index;
}
break;
}
if(index==0){
inteStr.append(".");
}
tempD = deci*2;
inteStr.append((int)tempD);
deci = sub(tempD ,(int)tempD);
index;
if(index%4 == 0){
inteStr.append(" ");
}
}
return inteStr.toString();
}
/**
* 提供精确的减法运算 。
* @param v1 被减数
* @param v2 减数
* @return 两个参数的差
*/
public static double sub(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.subtract(b2).doubleValue();
}
}
例如将十进制数1234.5转成二进制数为:0100 1101 0010.1000
怎么用java代码实现开平方算法?这是我应聘时写的算法代码,运行成功:
//这是用java编写的一个求2的平方根的程序,精确度可通过修改weishu参数来改变
public class app
{ //用二分法求2的平方根
public static void main(String args[])
{
int a[],b[],s[],d[],c[],ss[];
int i,j,k;
a=new int[1000];
b=new int[1000];
s=new int[1000];
d=new int[1000];
c=new int[1000];
ss=new int[1000];
boolean jingque;
jingque=true;
a[0]=b[0]=2;
a[2]=b[2]=1;
a[1]=4;
b[1]=5;
int weishu=200;//定义循环次数
for(i=0;i1000;i)
s[i]=0;
for(k=0;kweishu;k)
{
hanshucheng.cheng(b,b,s);
j=s[0];
while (s[j]=2)
{
hanshuadd.add(a,b,c);
hanshuchu.chu(d,c);
hanshucopy.copy(ss,b);
hanshucopy.copy(b,d);
hanshucheng.cheng(b,b,s);
j=s[0];
// for(i=0;i=s[0];i)
//System.out.println("s[" i "]=" s[i]);
}
hanshucopy.copy(a,b);
hanshucopy.copy(b,ss);
}
for(i=a[0];i=1;i--)
System.out.print(a[i]);
System.out.print("左边计算到" a[0] "位\n");
for(i=b[0];i=1;i--)
System.out.print(b[i]);
System.out.print("右边计算到" b[0] "位\n");
for(i=a[0],j=b[0];jingque==true;i--,j--)
if(a[i]==b[j])
System.out.print(a[i]);
else
jingque=false;
System.out.print("精确到" (a[0]-i-1) "位\n");
}
}
class hanshucheng
{
public static void cheng( int a[],int b[],int s[])//定义两数相乘的函数
{
int flag=0,flag1=0;
int number=b[0];
int c[]=new int[1000];
int i,j,k,u;
for(int i1=0;i11000;i1)
s[i1]=0;
for(i=1;i=number;i)
{
for(int i1=0;i11000;i1)
c[i1]=0;
for(j=i,k=1;jnumber i;j,k)
{
c[j]=(a[k]*b[i] flag);
flag=(a[k]*b[i] flag)/10;
}
if (flag!=0)
{
c[j]=flag;
flag=0;
j=j 1;
}
c[0]=j-1;
//for(k=1;k=c[0];k)
//System.out.println("c=" c[k]);
for(k=1;k=c[0];k)
{ u=s[k];
s[k]=(u c[k] flag1);
flag1=(u c[k] flag1)/10;
}
if(flag1!=0)
{
s[k]=flag1;
k=k 1;
flag1=0;
}
s[0]=k-1;
// for(k=0;k=s[0];k)
//System.out.println(s[k]);
}
}
}
class hanshuadd
{
public static void add(int a[],int b[],int c[])//定义两数相加的函数
{
int flag=0;int i,j,k;
int a1[]=new int[1000];
for(i=1;i=b[0];i)
a1[i]=0;
for(j=b[0]-a[0] 1,k=1;j=b[0];j,k)
a1[j]=a[k];
//for(k=0;k=j;k)
//System.out.println("a1=" a1[k]);
for(i=1;i=b[0];i)
{
c[i]=(a1[i] b[i] flag);
flag=(a1[i] b[i] flag)/10;
}
if(flag!=0)
{
c[i]=flag;
i=i 1;
flag=0;
}
c[0]=i-1;
}
}
class hanshuchu
{
public static void chu(int d[],int a[])//定义任一数除以2的函数
{
int flag=0,i;
for(i=a[0];i=1;i--)
{
d[i 1]=(flag*10 a[i])/2;
flag=(flag*10 a[i])%2;
}
if(flag!=0)
d[1]=5;
if(d[1]==0)
for(i=1;i=a[0] 1;i)
d[i]=d[i 1];
d[i]=0;
d[0]=a[0] 1;
}
}
class hanshucopy
{
public static void copy(int a[],int b[])//定义
{
int i;
for(i=0;i=b[0];i)
a[i]=b[i];
while (i1000)
a[i]=0;
}
}
用JAVA写一个a,b,c,d,e排列组合算法,谢谢了public class Paixu {
public static void main(String[] args) {
char[] in = "abcde".toCharArray();
new Paixu().paixu(in, in.length, 0);
}
private void paixu(char[] array, int n, int k) {
if (n == k) {
char[] out = new char[n];
for (int i = 0; iarray.length; i) {
out[i] = array[i];
}
System.out.println(new String(out));
} else {
for (int i = k; in; i) {
swap(array, k, i);
paixu(array, n, k1);
swap(array, i, k);
}
}
}
private void swap(char[] a, int x, int y) {
char temp = a[x];
a[x] = a[y];
a[y] = temp;
}
}
java十进制转二进制的代码是什么?import java.math.BigDecimal;
public class Test {
public static void main(String[] args) {
Test t = new Test();
double d = 8;
String s = t.decimal2BinaryStr(d);
System.out.println("十进制数" d "转成二进制数为:" s);
}
/**
* 十进制数转二进制数
* @param d 十进制数
* @return 十进制数转换成二进制的字符串
*/
public String decimal2BinaryStr(double d){
String result = decimal2BinaryStr_Inte(d);
result= decimal2BinaryStr_Deci(d);
return result;
}
/**
* 十进制整数部分转二进制数
* @param d 十进制数
* @return 十进制整数部分转换成二进制的字符串
*/
public String decimal2BinaryStr_Inte(double d){
//return Integer.toBinaryString((int)d);
/*
一、java的简介
java是由Sun Microsystems公司推出的Java面向对象程序设计语言(以下简称Java语言)和Java平台的总称 。
Java由James Gosling和同事们共同研发D算法java代码,并在1995年正式推出 。Java最初被称为OakD算法java代码,是1991年为消费类电子产品的嵌入式芯片而设计的 。
Java被广泛接受并推动D算法java代码了Web的迅速发展D算法java代码,常用的浏览器均支持Javaapplet 。另一方面,Java技术也不断更新 。Java自面世后就非常流行,发展迅速,对C语言形成有力冲击 。
在全球云计算和移动互联网的产业环境下 , Java更具备D算法java代码了显著优势和广阔前景 。2010年Oracle公司收购Sun Microsystems 。
0 || (C D)=0)解析成JAVA代码里的逻辑,其中ABCD为变量 。'>JAVA里如何实现动态算法?如把一个算式((A*B)>0 || (C D)=0)解析成JAVA代码里的逻辑,其中ABCD为变量 。这个是这样的,|| 是短路或操作,就是说前面一个表达式 为假时才执行后面一个表达式,即
当 (A*B) 0 时 不执行 (C D) == 0 判断操作(其实是==,单个等号是赋值)
当 (A*B) = 0 时 执行(C D)==0判断
你问出这个问题只能说明你的大学教授水平比较次 。。。。。
D算法java代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java算法总结、D算法java代码的信息别忘了在本站进行查找喔 。

    推荐阅读