java bitset 获取素数
查看
https://blog.csdn.net/lushuaiyin/article/details/7546733
bitset 操作
import java.util.*;
import java.util.stream.Collectors;
public class BitSetDemo {
/**
* 求一个字符串包含的char
*
*/
public static void containChars(String str) {
BitSet used = new BitSet();
for (int i = 0; i < str.length(); i++)
used.set(str.charAt(i)); // set bit for char
StringBuilder sb = new StringBuilder();
sb.append("[");
int size = used.size();
System.out.println(size);
for (int i = 0; i < size; i++) {
// System.out.println(used.get(i));
if (used.get(i)) {
sb.append((char) i);
System.out.print(1);
// System.out.println(i);
}else {
System.out.print(0);
}
}
sb.append("]");
System.out.println(sb.toString());
}
/**
* 求素数 有无限个。一个大于1的自然数,如果除了1和它本身外,不能被其他自然数整除(除0以外)的数称之为素数(质数) 否则称为合数
*/
public static void computePrime() {
BitSet sieve = new BitSet(1024);
int size = sieve.size();
for (int i = 2; i < size; i++)
sieve.set(i);
System.out.println(size);
int finalBit = (int) Math.sqrt(sieve.size());
// System.out.println(finalBit*32);
for (int i = 2; i < size; i++) {
System.out.print(sieve.get(i)?1:0);
}
System.out.println();
for (int i = 2; i < finalBit; i++) {
System.out.print(sieve.get(i)?1:0);
if (sieve.get(i)) {
for (int j = 2 * i; j < size; j += i)
sieve.clear(j);
}
}
System.out.println();
//
// int counter = 0;
// for (int i = 1; i < size; i++) {
// if (sieve.get(i)) {
// System.out.printf("%5d", i);
// if (++counter % 15 == 0)
// System.out.println();
// }
// }
// System.out.println();
}
/**
* 进行数字排序
*/
public static void sortArray() {
int[] array = new int[] { 423, 700, 9999, 2323, 356, 6400, 1,2,3,2,2,2,2 };
BitSet bitSet = new BitSet(2 << 13);
// 虽然可以自动扩容,但尽量在构造时指定估算大小,默认为64
System.out.println("BitSet size: " + bitSet.size());
for (int i = 0; i < array.length; i++) {
bitSet.set(array[i]);
}
//剔除重复数字后的元素个数
int bitLen=bitSet.cardinality();
//进行排序,即把bit为true的元素复制到另一个数组
int[] orderedArray = new int[bitLen];
int k = 0;
for (int i = bitSet.nextSetBit(0); i >= 0; i = bitSet.nextSetBit(i + 1)) {
orderedArray[k++] = i;
}
System.out.println("After ordering: ");
for (int i = 0; i < bitLen; i++) {
System.out.print(orderedArray[i] + "\t");
}
System.out.println("iterate over the true bits in a BitSet");
//或直接迭代BitSet中bit为true的元素iterate over the true bits in a BitSet
for (int i = bitSet.nextSetBit(0); i >= 0; i = bitSet.nextSetBit(i + 1)) {
System.out.print(i+"\t");
}
System.out.println("---------------------------");
}
/**
* 将BitSet对象转化为ByteArray
* @param bitSet
* @return
*/
public static byte[] bitSet2ByteArray(BitSet bitSet) {
byte[] bytes = new byte[bitSet.size() / 8];
for (int i = 0; i < bitSet.size(); i++) {
int index = i / 8;
int offset = 7 - i % 8;
bytes[index] |= (bitSet.get(i) ? 1 : 0) << offset;
}
return bytes;
}
/**
* 将ByteArray对象转化为BitSet
* @param bytes
* @return
*/
public static BitSet byteArray2BitSet(byte[] bytes) {
BitSet bitSet = new BitSet(bytes.length * 8);
int index = 0;
for (int i = 0; i < bytes.length; i++) {
for (int j = 7; j >= 0; j--) {
bitSet.set(index++, (bytes[i] & (1 << j)) >> j == 1 ? true
: false);
}
}
return bitSet;
}
/**
* 简单使用示例
*/
public static void simpleExample() {
String names[] = { "Java", "Source", "and", "Support" };
BitSet bits = new BitSet();
for (int i = 0, n = names.length; i < n; i++) {
if ((names[i].length() % 2) == 0) {
bits.set(i);
}
}
System.out.println(bits);
System.out.println("Size : " + bits.size());
System.out.println("Length: " + bits.length());
for (int i = 0, n = names.length; i < n; i++) {
if (!bits.get(i)) {
System.out.println(names[i] + " is odd");
}
}
BitSet bites = new BitSet();
bites.set(0);
bites.set(1);
bites.set(2);
bites.set(3);
bites.andNot(bits);
System.out.println(bites);
}
public static void main(String args[]) {
//BitSet使用示例
// BitSetDemo.containChars("123ioo");
//
//
BitSetDemo.computePrime();
// BitSetDemo.sortArray();
// BitSetDemo.simpleExample();
//
//
// //BitSet与Byte数组互转示例
// BitSet bitSet = new BitSet();
// bitSet.set(3, true);
// bitSet.set(98, true);
// System.out.println(bitSet.size()+","+bitSet.cardinality());
// //将BitSet对象转成byte数组
// byte[] bytes = BitSetDemo.bitSet2ByteArray(bitSet);
// System.out.println(Arrays.toString(bytes));
//
// //在将byte数组转回来
// bitSet = BitSetDemo.byteArray2BitSet(bytes);
// System.out.println(bitSet.size()+","+bitSet.cardinality());
// System.out.println(bitSet.get(3));
// System.out.println(bitSet.get(98));
// for (int i = bitSet.nextSetBit(0); i >= 0; i = bitSet.nextSetBit(i + 1)) {
// System.out.print(i+"\t");
// }
}
}
本文介绍了 Java 中 BitSet 类的应用场景,包括字符集提取、素数计算、数组排序及 BitSet 与字节数组间的转换等实用功能实现。
3716

被折叠的 条评论
为什么被折叠?



