Java编程入门练习题【附源码】
其中,上半部分菱形是通过两个嵌套的循环来打印的,第一个循环控制行数,第二个循环控制每一行中的空格和星号个数。通过完成这些练习题,你将学会如何使用Java编写简单的程序,处理输入和输出,以及利用常见的数据结构和算法。然后,它检查是否存在多于一个奇数次出现的字符,如果存在,则说明不是回文排列。这些练习题的难度逐渐增加,从简单的开始,逐步引导您掌握更多复杂的概念和技术。无论你是想要巩固基础知识,提高编程
目录
3、从控制台读取用户输入的姓名,并打印"Hello, [姓名]!"。
11、将一个字符串数组中的元素连接成一个大字符串并打印结果。
17、计算并打印Fibonacci数列的前n个数字,n由用户指定。
18、按照给定的分隔符将一个字符串拆分成子字符串并打印结果。
25、给定一个字符串,统计其中每个字符出现的次数并打印结果。
47、打印所有满足以下条件的三位数:该数字等于其各位数字的立方和。
一、引言
欢迎来到Java编程入门练习题!Java是一种通用且广泛使用的编程语言,具有跨平台性、面向对象和高性能的特点。无论你是初学者还是已经有一些编程经验的开发人员,这些练习题都将帮助你深入了解Java语言的基础知识和核心概念。
本系列练习题旨在帮助你巩固对Java语言的理解,并提供实际编码的机会。每个练习题都包含具体的问题描述和要求,你需要根据题目要求编写相应的Java代码来解决问题。通过完成这些练习题,你将学会如何使用Java编写简单的程序,处理输入和输出,以及利用常见的数据结构和算法。
这些练习题的难度逐渐增加,从简单的开始,逐步引导您掌握更多复杂的概念和技术。无论你是想要巩固基础知识,提高编程技能,还是准备进一步学习Java的高级主题,这些练习题都会给你提供一个良好的起点。
你可以在完成每个练习题后,查看提供的参考答案,并与之进行比较。这将帮助你更好地理解问题的解决方法,并发现自己可能存在的错误或改进空间。
Java编程入门练习题是一个互动学习的过程,鼓励你积极参与并尝试自己的解决方案。无论遇到什么困难,坚持下去,并不断加强你的编码能力和问题解决技巧。相信通过这些练习题,你将迅速提高自己的Java编程水平。
祝你在这个学习过程中取得成功,享受编程的乐趣!
开始吧!让我们一起探索Java编程的奇妙世界吧!
二、练习题
1、打印"Hello, World!"到控制台。
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello, World!");
}
}
2、将两个整数相加并打印结果。
public class AddTwoNumbers {
public static void main(String[] args) {
int num1 = 5;
int num2 = 10;
int sum = num1 + num2;
System.out.println("两个整数的和为:" + sum);
}
}
3、从控制台读取用户输入的姓名,并打印"Hello, [姓名]!"。
import java.util.Scanner;
public class HelloWorld {
public static void main(String[] args) {
// 创建一个Scanner对象,用于读取用户输入
Scanner scanner = new Scanner(System.in);
// 提示用户输入姓名
System.out.print("请输入您的姓名: ");
// 读取用户输入的姓名
String name = scanner.nextLine();
// 打印问候语
System.out.println("Hello, " + name + "!");
// 关闭Scanner对象
scanner.close();
}
}
4、计算并打印给定整数数组的和。
public class Main {
public static void main(String[] args) {
int[] numbers = { 1, 2, 3, 4, 5 };
int sum = calculateSum(numbers);
System.out.println("数组的和为:" + sum);
}
public static int calculateSum(int[] arr) {
int sum = 0;
for (int num : arr) {
sum += num;
}
return sum;
}
}
5、将给定字符串反转并打印结果。
public class StringReverse {
public static void main(String[] args) {
String input = "Hello, World!";
String reversed = reverseString(input);
System.out.println(reversed);
}
public static String reverseString(String str) {
StringBuilder sb = new StringBuilder(str);
sb.reverse();
return sb.toString();
}
}
6、检查给定字符串是否是回文,并打印结果。
import java.util.Scanner;
public class PalindromeChecker {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个字符串:");
String input = scanner.nextLine();
if (isPalindrome(input)) {
System.out.println(input + " 是一个回文字符串。");
} else {
System.out.println(input + " 不是一个回文字符串。");
}
}
private static boolean isPalindrome(String str) {
int left = 0;
int right = str.length() - 1;
while (left < right) {
if (str.charAt(left) != str.charAt(right)) {
return false;
}
left++;
right--;
}
return true;
}
}
7、打印1到100之间的所有奇数。
public class PrintOddNumbers {
public static void main(String[] args) {
for (int i = 1; i <= 100; i++) {
if (i % 2 != 0) {
System.out.println(i);
}
}
}
}
8、打印1到100之间的所有偶数。
public class PrintEvenNumbers {
public static void main(String[] args) {
for (int i = 1; i <= 100; i++) {
if (i % 2 == 0) {
System.out.println(i);
}
}
}
}
9、将给定的整数数组按照升序排序并打印结果。
import java.util.Arrays;
public class SortArray {
public static void main(String[] args) {
int[] array = {5, 2, 9, 1, 3};
// 使用Arrays类的sort方法对数组进行排序
Arrays.sort(array);
// 打印排序后的结果
System.out.println("排序后的数组:");
for (int num : array) {
System.out.print(num + " ");
}
}
}
10、判断给定的整数是否为素数,并打印结果。
import java.util.Scanner;
public class PrimeNumberChecker {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个整数:");
int number = scanner.nextInt();
boolean isPrime = true;
if (number <= 1) {
isPrime = false;
} else {
for (int i = 2; i <= Math.sqrt(number); i++) {
if (number % i == 0) {
isPrime = false;
break;
}
}
}
if (isPrime) {
System.out.println(number + " 是素数。");
} else {
System.out.println(number + " 不是素数。");
}
}
}
11、将一个字符串数组中的元素连接成一个大字符串并打印结果。
public class StringArrayConcatenation {
public static void main(String[] args) {
String[] stringArray = {"Hello", " ", "World!"};
// 使用StringBuilder来连接字符串
StringBuilder stringBuilder = new StringBuilder();
for (String str : stringArray) {
stringBuilder.append(str);
}
// 将连接后的字符串转换为普通的String对象
String result = stringBuilder.toString();
// 打印结果
System.out.println(result);
}
}
12、检查给定的字符串是否是有效的手机号码,并打印结果。
import java.util.regex.*;
public class PhoneNumberValidator {
public static void main(String[] args) {
String phoneNumber = "1234567890"; // 替换为要检查的手机号码
boolean isValid = validatePhoneNumber(phoneNumber);
if (isValid) {
System.out.println(phoneNumber + " 是有效的手机号码");
} else {
System.out.println(phoneNumber + " 不是有效的手机号码");
}
}
public static boolean validatePhoneNumber(String phoneNumber) {
// 使用正则表达式进行手机号码验证
String regex = "^(\\+\\d{1,3})?[- .]?\\(?\\d{3}\\)?[- .]?\\d{3}[- .]?\\d{4}$";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(phoneNumber);
return matcher.matches();
}
}
13、计算并打印给定整数的阶乘。
import java.util.Scanner;
public class Factorial {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个整数:");
int num = scanner.nextInt();
long factorial = calculateFactorial(num);
System.out.println(num + "的阶乘为:" + factorial);
}
// 计算给定整数的阶乘
public static long calculateFactorial(int num) {
if (num < 0) {
throw new IllegalArgumentException("不能计算负数的阶乘");
}
long factorial = 1;
for (int i = 1; i <= num; i++) {
factorial *= i;
}
return factorial;
}
}
14、打印一个n行的等腰三角形,n由用户指定。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入要打印的等腰三角形的行数:");
int n = scanner.nextInt();
for (int i = 1; i <= n; i++) {
// 打印空格
for (int j = 1; j <= n - i; j++) {
System.out.print(" ");
}
// 打印星号
for (int k = 1; k <= 2 * i - 1; k++) {
System.out.print("*");
}
// 换行
System.out.println();
}
}
}
15、检查给定字符串是否是有效的邮箱地址,并打印结果。
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class EmailValidation {
public static void main(String[] args) {
String email = "example@example.com"; // 要验证的邮箱地址
// 正则表达式模式匹配邮箱地址
String emailPattern = "^[A-Za-z0-9+_.-]+@[A-Za-z0-9.-]+$";
// 创建Pattern对象
Pattern pattern = Pattern.compile(emailPattern);
// 创建Matcher对象
Matcher matcher = pattern.matcher(email);
// 检查是否匹配有效的邮箱地址
if (matcher.matches()) {
System.out.println("有效的邮箱地址");
} else {
System.out.println("无效的邮箱地址");
}
}
}
16、给定一个矩阵,将其转置并打印结果。
public class MatrixTranspose {
public static void main(String[] args) {
int[][] matrix = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
int rows = matrix.length;
int columns = matrix[0].length;
// 创建一个新的矩阵用于存储转置后的结果
int[][] transposeMatrix = new int[columns][rows];
// 将原矩阵的行变成转置矩阵的列
for (int i = 0; i < rows; i++) {
for (int j = 0; j < columns; j++) {
transposeMatrix[j][i] = matrix[i][j];
}
}
// 打印转置后的矩阵
System.out.println("转置后的矩阵:");
for (int i = 0; i < columns; i++) {
for (int j = 0; j < rows; j++) {
System.out.print(transposeMatrix[i][j] + " ");
}
System.out.println();
}
}
}
17、计算并打印Fibonacci数列的前n个数字,n由用户指定。
import java.util.Scanner;
public class FibonacciSeries {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入要计算的Fibonacci数列的长度(n):");
int n = scanner.nextInt();
System.out.println("Fibonacci数列的前 " + n + " 个数字为:");
// 计算并打印Fibonacci数列的前n个数字
for (int i = 1; i <= n; i++) {
System.out.print(fibonacci(i) + " ");
}
}
// 计算第n个Fibonacci数
public static int fibonacci(int n) {
if (n <= 1) {
return n;
} else {
return fibonacci(n - 1) + fibonacci(n - 2);
}
}
}
请注意,此代码中使用递归来计算Fibonacci数列。对于较大的n值,可能会出现性能问题。如果需要处理更大的n值,可以尝试使用迭代方法来计算Fibonacci数列。
18、按照给定的分隔符将一个字符串拆分成子字符串并打印结果。
public class StringSplitExample {
public static void main(String[] args) {
String inputString = "Hello,World!How,are,you?";
String delimiter = ","; // 分隔符
// 使用split方法将输入字符串拆分成子字符串
String[] subStrings = inputString.split(delimiter);
// 打印拆分后的子字符串
for (String subString : subStrings) {
System.out.println(subString);
}
}
}
19、将给定的整数数组中的元素去重并打印结果。
import java.util.Arrays;
import java.util.HashSet;
public class Main {
public static void main(String[] args) {
int[] arr = {1, 2, 3, 4, 5, 5, 6, 6, 7, 8, 9, 9};
// 使用 HashSet 去重
HashSet<Integer> set = new HashSet<>();
for (int num : arr) {
set.add(num);
}
// 将去重后的元素转换为数组
Integer[] uniqueArr = set.toArray(new Integer[set.size()]);
// 打印去重后的数组元素
System.out.println(Arrays.toString(uniqueArr));
}
}
20、打印1到100之间所有能被3和5同时整除的数字。
public class Main {
public static void main(String[] args) {
for (int i = 1; i <= 100; i++) {
if (i % 3 == 0 && i % 5 == 0) {
System.out.println(i);
}
}
}
}
21、判断给定的字符串是否是回文数,并打印结果。
public class Palindrome {
public static void main(String[] args) {
String str = "level"; // 要判断的字符串
// 将字符串反转
StringBuilder reversedStr = new StringBuilder(str);
reversedStr.reverse();
// 判断反转后的字符串与原始字符串是否相等
if (str.equals(reversedStr.toString())) {
System.out.println("是回文数");
} else {
System.out.println("不是回文数");
}
}
}
22、按照给定的格式打印当前日期和时间。
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
public class PrintDateTime {
public static void main(String[] args) {
// 获取当前日期和时间
LocalDateTime currentDateTime = LocalDateTime.now();
// 定义日期时间格式
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
// 格式化日期时间并打印
String formattedDateTime = currentDateTime.format(formatter);
System.out.println("当前日期和时间: " + formattedDateTime);
}
}
23、检查给定的整数是否为完全平方数,并打印结果。
public class PerfectSquareChecker {
public static void main(String[] args) {
int num = 16; // 要检查的整数
if (isPerfectSquare(num)) {
System.out.println(num + " 是一个完全平方数。");
} else {
System.out.println(num + " 不是一个完全平方数。");
}
}
public static boolean isPerfectSquare(int num) {
if (num < 0) {
return false;
}
if (num == 0 || num == 1) {
return true;
}
long start = 1;
long end = num;
while (start <= end) {
long mid = (start + end) / 2;
long square = mid * mid;
if (square == num) {
return true;
} else if (square < num) {
start = mid + 1;
} else {
end = mid - 1;
}
}
return false;
}
}
24、计算并打印斐波那契数列的第n个数字,n由用户指定。
import java.util.Scanner;
public class FibonacciSeries {
public static void main(String[] args) {
// 获取用户输入的n值
Scanner scanner = new Scanner(System.in);
System.out.print("请输入要计算的斐波那契数列的第几个数字:");
int n = scanner.nextInt();
// 调用方法计算并打印第n个数字
int result = fibonacci(n);
System.out.println("斐波那契数列的第" + n + "个数字是:" + result);
}
public static int fibonacci(int n) {
if (n <= 1) {
return n;
} else {
int a = 0;
int b = 1;
int temp;
for (int i = 2; i <= n; i++) {
temp = a + b;
a = b;
b = temp;
}
return b;
}
}
}
25、给定一个字符串,统计其中每个字符出现的次数并打印结果。
import java.util.HashMap;
import java.util.Map;
public class CharacterCount {
public static void main(String[] args) {
String str = "Hello, World!";
Map<Character, Integer> charCountMap = new HashMap<>();
// 遍历字符串中的每个字符
for (int i = 0; i < str.length(); i++) {
char ch = str.charAt(i);
// 将字符添加到map中,并更新其出现次数
if (charCountMap.containsKey(ch)) {
int count = charCountMap.get(ch);
charCountMap.put(ch, count + 1);
} else {
charCountMap.put(ch, 1);
}
}
// 打印各字符出现的次数
for (Map.Entry<Character, Integer> entry : charCountMap.entrySet()) {
System.out.println(entry.getKey() + " : " + entry.getValue());
}
}
}
26、判断给定的字符串是否是有效的IP地址,并打印结果。
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class ValidateIPAddress {
public static void main(String[] args) {
String ipAddress = "192.168.0.1";
boolean isValidIP = validateIPAddress(ipAddress);
System.out.println("Is valid IP address: " + isValidIP);
}
public static boolean validateIPAddress(String ipAddress) {
// IP地址的正则表达式模式
String pattern = "^([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
+ "([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
+ "([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
+ "([01]?\\d\\d?|2[0-4]\\d|25[0-5])$";
Pattern regexPattern = Pattern.compile(pattern);
Matcher matcher = regexPattern.matcher(ipAddress);
return matcher.matches();
}
}
27、将给定的整数数组逆序排列并打印结果。
import java.util.Arrays;
public class ReverseArray {
public static void main(String[] args) {
int[] arr = {1, 2, 3, 4, 5};
System.out.println("原始数组:");
System.out.println(Arrays.toString(arr));
reverseArray(arr);
System.out.println("逆序排列后的数组:");
System.out.println(Arrays.toString(arr));
}
public static void reverseArray(int[] arr) {
int start = 0;
int end = arr.length - 1;
while (start < end) {
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
start++;
end--;
}
}
}
28、检查给定的字符串是否是回文串,并打印结果。
public class PalindromeChecker {
public static void main(String[] args) {
String str = "madam"; // 要检查的字符串
// 去除字符串中的空格和标点符号,并转换为小写
String cleanedStr = str.replaceAll("[^a-zA-Z0-9]", "").toLowerCase();
boolean isPalindrome = checkPalindrome(cleanedStr);
if (isPalindrome) {
System.out.println(str + " 是一个回文串");
} else {
System.out.println(str + " 不是一个回文串");
}
}
private static boolean checkPalindrome(String str) {
int left = 0;
int right = str.length() - 1;
while (left < right) {
if (str.charAt(left) != str.charAt(right)) {
return false;
}
left++;
right--;
}
return true;
}
}
29、判断给定的整数是否为质数,并打印结果。
import java.util.Scanner;
public class PrimeNumberChecker {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个整数:");
int number = scanner.nextInt();
boolean isPrime = true;
// 如果输入的整数小于等于1,则不是质数
if (number <= 1) {
isPrime = false;
} else {
// 从2开始遍历到该整数的平方根
for (int i = 2; i <= Math.sqrt(number); i++) {
// 如果能被任何一个数整除,则不是质数
if (number % i == 0) {
isPrime = false;
break;
}
}
}
if (isPrime) {
System.out.println(number + " 是质数");
} else {
System.out.println(number + " 不是质数");
}
}
}
30、对给定的字符串进行加密并打印结果。
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class StringEncryption {
public static void main(String[] args) {
String inputString = "Hello, World!";
// 加密输入字符串
String encryptedString = encryptString(inputString);
System.out.println("加密后的字符串:" + encryptedString);
}
public static String encryptString(String input) {
try {
// 创建MD5消息摘要对象
MessageDigest messageDigest = MessageDigest.getInstance("MD5");
// 将输入字符串转换为字节数组
byte[] inputBytes = input.getBytes();
// 计算字节数组的摘要
byte[] hashedBytes = messageDigest.digest(inputBytes);
// 将字节数组转换为十六进制字符串
StringBuilder hexString = new StringBuilder();
for (byte b : hashedBytes) {
String hex = Integer.toHexString(0xff & b);
if (hex.length() == 1) {
hexString.append('0');
}
hexString.append(hex);
}
// 返回加密后的字符串
return hexString.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
}
}
在此示例代码中,我们使用了java.security.MessageDigest
类来进行字符串的加密。它提供了多种加密算法,这里我们选择了常用的MD5算法。首先,我们定义了一个encryptString
方法,该方法接受一个字符串作为输入,将其转化为字节数组,并计算其摘要。然后,我们将摘要转化为十六进制字符串形式,并返回结果。
在main
方法中,我们定义了一个输入字符串"Hello, World!"
,然后调用encryptString
方法对其进行加密,并将结果打印输出。
请注意,MD5算法是一种单向散列函数,它只能对数据进行加密,无法解密。因此,加密后的字符串不能被还原为原始字符串。
31、将一个二进制字符串转换为十进制整数并打印结果。
public class BinaryToDecimal {
public static void main(String[] args) {
String binaryString = "101010"; // 二进制字符串
int decimal = Integer.parseInt(binaryString, 2); // 将二进制字符串转换为十进制整数
System.out.println("Decimal: " + decimal); // 打印十进制结果
}
}
在此示例中,我们使用Integer.parseInt(binaryString, 2)
方法将二进制字符串转换为十进制整数。然后,使用System.out.println()
语句打印出转换后的十进制结果。请根据需要修改binaryString
变量的值来测试不同的二进制字符串。
32、检查给定的两个字符串是否是同构的,并打印结果。
import java.util.HashMap;
import java.util.Map;
public class IsomorphicStrings {
public static boolean isIsomorphic(String s, String t) {
if (s.length() != t.length()) {
return false;
}
Map<Character, Character> map = new HashMap<>();
Map<Character, Boolean> used = new HashMap<>();
for (int i = 0; i < s.length(); i++) {
char c1 = s.charAt(i);
char c2 = t.charAt(i);
if (map.containsKey(c1)) {
if (map.get(c1) != c2) {
return false;
}
} else {
if (used.containsKey(c2)) {
return false;
}
map.put(c1, c2);
used.put(c2, true);
}
}
return true;
}
public static void main(String[] args) {
String s1 = "egg";
String t1 = "add";
System.out.println("Are \"" + s1 + "\" and \"" + t1 + "\" isomorphic? " + isIsomorphic(s1, t1));
String s2 = "paper";
String t2 = "title";
System.out.println("Are \"" + s2 + "\" and \"" + t2 + "\" isomorphic? " + isIsomorphic(s2, t2));
String s3 = "foo";
String t3 = "bar";
System.out.println("Are \"" + s3 + "\" and \"" + t3 + "\" isomorphic? " + isIsomorphic(s3, t3));
}
}
这段代码定义了一个静态方法isIsomorphic
,它接受两个字符串作为参数并返回一个布尔值,表示这两个字符串是否是同构的。该方法使用了两个哈希映射map
和used
来进行判断。
在main
函数中,我们调用isIsomorphic
方法来检查不同的字符串对是否是同构的,并打印出结果。
33、计算并打印给定整数的平方根。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个整数:");
int num = scanner.nextInt();
double squareRoot = Math.sqrt(num);
System.out.println("该整数的平方根为:" + squareRoot);
}
}
这段代码首先需要导入Scanner
类,以便从控制台读取用户输入。然后,通过创建Scanner
对象,并使用nextInt()
方法获取用户输入的整数。
接下来,使用Math.sqrt()
方法计算给定整数的平方根,并将结果存储在squareRoot
变量中。最后,使用System.out.println()
语句打印出平方根的值。
注意:此代码假设用户输入的是有效的整数。如果用户输入的不是整数或负数,则可能会抛出异常。因此,应添加适当的错误处理机制来处理这种情况。
34、给定一个正整数n,打印一个n行的倒立金字塔。
import java.util.Scanner;
public class InvertedPyramid {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个正整数 n:");
int n = scanner.nextInt();
for (int i = n; i >= 1; i--) {
// 打印空格
for (int j = 0; j < n - i; j++) {
System.out.print(" ");
}
// 打印星号
for (int k = 1; k <= 2 * i - 1; k++) {
System.out.print("*");
}
// 换行
System.out.println();
}
}
}
这段代码首先从用户输入中获取一个正整数n。然后使用两层循环,外层循环控制行数,内层循环分别打印空格和星号。每一行的空格数量为 n - i
,星号数量为 (2 * i - 1)
,其中i
为当前行数。最后换行输出结果。
请注意,上述代码假设输入的n为正整数。如果需要对输入进行合法性检查,可以添加一些额外的逻辑来处理非法输入。
35、 检查给定字符串是否是有效的URL,并打印结果。
import java.net.URL;
import java.net.MalformedURLException;
public class ValidURLChecker {
public static void main(String[] args) {
String urlStr = "https://www.example.com";
try {
URL url = new URL(urlStr);
System.out.println("输入的字符串是一个有效的URL。");
} catch (MalformedURLException e) {
System.out.println("输入的字符串不是一个有效的URL。");
}
}
}
在这个例子中,我们使用java.net.URL
类来创建URL对象。如果给定的字符串可以成功转换为一个URL对象,则说明它是一个有效的URL;否则,会抛出MalformedURLException
异常,表示给定的字符串不是一个有效的URL。
你可以将要检查的URL替换为urlStr
变量的值,然后运行该程序,它将打印结果。如果给定字符串是有效的URL,它将输出输入的字符串是一个有效的URL
;如果给定字符串不是有效的URL,它将输出输入的字符串不是一个有效的URL
。
36、 将给定的整数数组中的元素按照降序排序并打印结果。
import java.util.Arrays;
public class Main {
public static void main(String[] args) {
int[] array = {5, 2, 10, 8, 3};
// 使用Arrays.sort方法对数组进行排序,默认为升序排序
Arrays.sort(array);
// 将数组元素反转,实现降序排序
for (int i = 0; i < array.length / 2; i++) {
int temp = array[i];
array[i] = array[array.length - 1 - i];
array[array.length - 1 - i] = temp;
}
// 打印排序后的结果
for (int num : array) {
System.out.print(num + " ");
}
}
}
在这个程序中,我们使用了java.util.Arrays
类的sort
方法对整数数组进行升序排序。然后,通过交换数组元素的位置来实现降序排序,并使用for-each
循环打印排序后的结果。运行该程序会输出:10 8 5 3 2。
37、判断给定的字符串是否是回文排列,并打印结果。
import java.util.HashMap;
import java.util.Map;
public class PalindromePermutation {
public static boolean isPalindromePermutation(String str) {
// 创建一个HashMap,用于存储字符出现的次数
Map<Character, Integer> charCount = new HashMap<>();
// 统计每个字符出现的次数
for (char ch : str.toCharArray()) {
if (Character.isLetter(ch)) {
ch = Character.toLowerCase(ch);
charCount.put(ch, charCount.getOrDefault(ch, 0) + 1);
}
}
// 检查是否存在多于一个奇数次出现的字符
int oddCount = 0;
for (int count : charCount.values()) {
if (count % 2 != 0) {
oddCount++;
}
// 若存在超过一个奇数次出现的字符,则不是回文排列
if (oddCount > 1) {
return false;
}
}
return true;
}
public static void main(String[] args) {
String input = "tactcoapapa";
boolean result = isPalindromePermutation(input);
if (result) {
System.out.println("给定的字符串是回文排列");
} else {
System.out.println("给定的字符串不是回文排列");
}
}
}
该程序首先使用一个HashMap来统计给定字符串中每个字符出现的次数。然后,它检查是否存在多于一个奇数次出现的字符,如果存在,则说明不是回文排列。最后,根据判断结果打印相应的消息。以上代码演示了如何在Java中判断给定的字符串是否是回文排列,并输出结果。
38、打印1到100之间所有能同时被3、5和7整除的数字。
public class Main {
public static void main(String[] args) {
for (int i = 1; i <= 100; i++) {
if (i % 3 == 0 && i % 5 == 0 && i % 7 == 0) {
System.out.println(i);
}
}
}
}
这段代码使用for
循环遍历从1到100的所有数字。对于每个数字,通过使用取余运算符(%
)来检查是否能够被3、5和7整除。如果满足条件,则使用System.out.println()
语句将该数字打印出来。
39、计算并打印给定整数的平方。
import java.util.Scanner;
public class SquareCalculator {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个整数:");
int number = scanner.nextInt();
int square = number * number;
System.out.println(number + "的平方是:" + square);
scanner.close();
}
}
这段代码首先导入了java.util.Scanner
类,以便从控制台读取用户输入。然后,在main
方法中,我们创建了一个Scanner
对象scanner
。
接下来,代码会提示用户输入一个整数,并将其保存在变量number
中。
然后,使用number * number
计算出给定整数的平方,并将结果保存在变量square
中。
最后,通过使用System.out.println()
方法打印给定整数和其平方。
最后,调用scanner.close()
关闭Scanner
对象,以释放资源。
40、给定一个整数n,打印从1到n的所有素数。
public class PrimeNumbers {
public static void main(String[] args) {
int n = 100; // 在这里将n设置为所需的数字
System.out.println("从1到" + n + "的所有素数为:");
for (int i = 2; i <= n; i++) {
if (isPrime(i)) {
System.out.print(i + " ");
}
}
}
// 判断一个数字是否为素数的方法
public static boolean isPrime(int num) {
if (num <= 1) {
return false;
}
for (int i = 2; i <= Math.sqrt(num); i++) {
if (num % i == 0) {
return false;
}
}
return true;
}
}
41、将一个十进制整数转换为二进制字符串并打印结果。
public class DecimalToBinary {
public static void main(String[] args) {
int decimal = 10;
String binary = convertToBinary(decimal);
System.out.println("Binary representation of " + decimal + " is: " + binary);
}
public static String convertToBinary(int decimal) {
StringBuilder binary = new StringBuilder();
if (decimal == 0) {
return "0";
}
while (decimal > 0) {
int remainder = decimal % 2;
binary.insert(0, remainder);
decimal = decimal / 2;
}
return binary.toString();
}
}
这段代码定义了一个名为DecimalToBinary
的类,其中包含一个静态方法convertToBinary
。该方法接受一个十进制整数作为参数,并返回其对应的二进制表示形式的字符串。
在main
方法中,定义一个整数变量decimal
并赋值为10。然后调用convertToBinary
方法将该整数转换为二进制字符串,并将结果存储在binary
变量中。最后使用System.out.println
语句打印出转换结果。
运行上述代码将输出:Binary representation of 10 is: 1010
42、检查给定的两个字符串是否是旋转字符串,并打印结果。
public class CheckRotationString {
public static void main(String[] args) {
String str1 = "hello";
String str2 = "lohel";
if (isRotationString(str1, str2)) {
System.out.println("字符串是旋转字符串");
} else {
System.out.println("字符串不是旋转字符串");
}
}
public static boolean isRotationString(String str1, String str2) {
// 检查字符串长度是否相等
if (str1.length() != str2.length()) {
return false;
}
// 将 str1 连接自身,判断 str2 是否是连接后的字符串的子串
String concatenatedStr = str1 + str1;
if (concatenatedStr.contains(str2)) {
return true;
}
return false;
}
}
此代码将比较两个字符串 str1
和 str2
的长度是否相等。如果长度相等,则将 str1
连接自身成为 concatenatedStr
,然后检查 str2
是否是 concatenatedStr
的子串。如果是,则说明它们是旋转字符串;否则,它们不是旋转字符串。
在示例中,str1
的值为 "hello",str2
的值为 "lohel"。根据算法,它们被认为是旋转字符串,因为 str2
是 str1
连接自身后的子串。
43、计算并打印给定整数的立方根。
import java.util.Scanner;
public class CubeRoot {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个整数:");
int number = scanner.nextInt();
double cubeRoot = Math.cbrt(number);
System.out.println("立方根为:" + cubeRoot);
scanner.close();
}
}
这段代码首先导入java.util.Scanner
类,以便从用户输入读取整数。然后,它创建一个Scanner
对象并提示用户输入一个整数。
接下来,使用Math.cbrt()
方法计算给定整数的立方根,并将结果存储在cubeRoot
变量中。
最后,使用System.out.println()
语句打印立方根的值。
请注意,在运行此代码之前,确保您已经安装了Java开发环境(JDK)并正确设置了环境变量。
44、给定一个正整数n,打印一个n行的菱形图案。
import java.util.Scanner;
public class DiamondPattern {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个正整数:");
int n = scanner.nextInt();
// 打印上半部分菱形
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n - i; j++) {
System.out.print(" ");
}
for (int j = 1; j <= 2 * i - 1; j++) {
System.out.print("*");
}
System.out.println();
}
// 打印下半部分菱形
for (int i = n - 1; i >= 1; i--) {
for (int j = 1; j <= n - i; j++) {
System.out.print(" ");
}
for (int j = 1; j <= 2 * i - 1; j++) {
System.out.print("*");
}
System.out.println();
}
}
}
这段代码首先会提示用户输入一个正整数n,然后根据输入的n来打印一个n行的菱形图案。其中,上半部分菱形是通过两个嵌套的循环来打印的,第一个循环控制行数,第二个循环控制每一行中的空格和星号个数。下半部分菱形同样采用相似的方法打印,只是循环的条件和控制输出的内容稍有不同。
45、检查给定字符串是否是有效的IPv4地址,并打印结果。
import java.util.regex.Pattern;
public class IPv4Validator {
public static void main(String[] args) {
String ipAddress = "192.168.0.1";
boolean isValid = isValidIPv4(ipAddress);
System.out.println("Is valid IPv4 address? " + isValid);
}
public static boolean isValidIPv4(String ip) {
String pattern = "^((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$";
return Pattern.matches(pattern, ip);
}
}
这个代码定义了一个名为IPv4Validator
的类,其中包含一个静态方法isValidIPv4
。该方法使用正则表达式来验证给定的IP地址字符串是否是有效的IPv4地址。
在main
方法中,我们使用字符串"192.168.0.1"作为示例IP地址,并调用isValidIPv4
方法进行验证。最后,将验证结果打印出来。
你可以根据需要修改代码中的IP地址来测试不同的输入。
46、将给定的整数数组中的元素按照随机顺序排列并打印结果。
import java.util.Arrays;
import java.util.Random;
public class RandomizeArray {
public static void main(String[] args) {
int[] array = {1, 2, 3, 4, 5};
// 创建一个Random对象
Random random = new Random();
for (int i = 0; i < array.length; i++) {
// 生成一个随机索引
int randomIndex = random.nextInt(array.length);
// 交换当前位置和随机位置的元素
int temp = array[i];
array[i] = array[randomIndex];
array[randomIndex] = temp;
}
// 打印结果
System.out.println(Arrays.toString(array));
}
}
这段代码使用Random
类来生成随机数,并通过循环遍历数组元素,将每个元素与随机位置上的元素进行交换。最后,使用Arrays.toString()
方法将打乱后的数组结果打印出来。
47、打印所有满足以下条件的三位数:该数字等于其各位数字的立方和。
public class Main {
public static void main(String[] args) {
for (int i = 100; i < 1000; i++) {
int number = i;
int sumOfCubes = 0;
// 计算各位数字的立方和
while (number > 0) {
int digit = number % 10;
sumOfCubes += Math.pow(digit, 3);
number /= 10;
}
// 检查是否满足条件并打印结果
if (sumOfCubes == i) {
System.out.println(i);
}
}
}
}
48、计算并打印给定整数的立方。
import java.util.Scanner;
public class CubeCalculator {
public static void main(String[] args) {
// 创建 Scanner 对象以接收用户输入
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个整数: ");
int number = scanner.nextInt();
// 计算立方
int cube = number * number * number;
// 打印结果
System.out.println("整数 " + number + " 的立方是: " + cube);
// 关闭 Scanner 对象
scanner.close();
}
}
请注意,该代码通过 Scanner
类从用户那里接收输入。用户输入的整数将被存储在 number
变量中,并使用数学运算符计算立方。最后,结果将被打印到控制台上。
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)