1.有一个数列:8,4,2,1,23,344,12
循环输出数列的值
求数列中所有数值的和
猜数游戏:从键盘中任意输入一个数据,判断数列中是否包含此数
// 有一个数列:8,4,2,1,23,344,12
// 循环输出数列的值
// 求数列中所有数值的和
// 猜数游戏:从键盘中任意输入一个数据,判断数列中是否包含此数
int[] array = {8,4,2,1,23,344,12};
Scanner scanner = new Scanner(System.in);
System.out.println("请输入一个数");
int num = scanner.nextInt();
int i = 0;
//拿数组中的每一个元素和num比较,如果想等,输出包含,否则,输出不包含
for(i = 0; i < array.length; i++)
{
if(array[i]==num)
{
System.out.println("包含");
break;
}
}
//说明循环了一圈都没有发现用户输入的值
if(i==array.length)
{
System.out.println("不包含");
}
2.循环录入5位学员成绩,进行升序排列后输出结果
……
int[] scores = new int[5]; //成绩数组
Scanner input = new Scanner(System.in);
System.out.println("请输入5位学员的成绩:");
for(int i = 0; i < scores.length; i++){
scores[i] = input.nextInt();
}
Arrays.sort(scores);
System.out.print("学员成绩按升序排列:");
for(int i = 0; i < scores.length; i++){
System.out.print(scores[i] + " ");
}
3.从键盘输入本次Java考试五位学生的成绩,求考试成绩最高分
从键盘输入本次Java考试五位学生的成绩,求考试成绩最高分
//将5个成绩保存到数组中,
//然后,遍历数组,找出数组中最大的数
Scanner scanner = new Scanner(System.in);
System.out.println("请输入成绩");
int[] scores = new int[5];
//将5个成绩保存到数组中,
for(int i = 0; i < scores.length; i++)
{
System.out.println("输入第" + (i + 1) + "次成绩");
scores[i] = scanner.nextInt();
}
//然后,遍历数组,找出数组中最大的数
int max = scores[0];////让max等于数组中第一个元素
for(int i = 1; i < scores.length; i++)
{
if(max < scores[i])
{
max = scores[i];//谁比他大,他就变成谁
}
}
System.out.println("最大值是" + max);
4.有一组学员的成绩{99,85,82,63, 60},将它们按升序排列。要增加一个学员的成绩,将它插入成绩序列,并保持升序。
int[] scores = {99,85,82,63, 60};
Arrays.sort(scores);
for(int i = 0; i < scores.length; i++)
{
System.out.print(scores[i]+" ");
}
// 要增加一个学员的成绩,将它插入成绩序列,并保持升序
Scanner scanner = new Scanner(System.in);
System.out.println("请输入下一个学生成绩");
int input = scanner.nextInt();
int pos = 0;//用户输入的数在新数组中正确的插入位置
//遍历原始数组,找到要插入的位置
for(int i = 0; i < scores.length; i++)
{
if(input <= scores[i])
{
pos = i;
break;
}
}
//再建一个新的数组,包含6个元素
int[] scores2 = new int[6];
//拷贝旧数组从0开始
// 到pos位置的数到对应新数组同样下标中
for(int i = 0; i < pos; i++)
{
scores2[i] = scores[i];
}
scores2[pos] = input;
//拷贝旧数组从pos+1开始
// 到旧数组长度位置的数到对应新数组同样下标中
for(int i = pos+1; i < scores2.length; i++)
{
scores2[i] = scores[i-1];
}
for(int i = 0; i<scores2.length; i++)
{
System.out.print(scores2[i]+" ");
}
b.冒泡排序
public static void main(String[] args) {
int score[] = {99, 85, 82, 63, 60};
int score1[] = new int[6];int i;
Arrays.sort(score);
for (int j = 0; j < score.length; j++) {
score1[j] = score[j];
}
System.out.println("输入插入的学生成绩");
Scanner scanner = new Scanner(System.in);
score1[5] = scanner.nextInt();
// for (int k = 0; k < score1.length-1; k++) {
// for ( i = 0; i < score1.length-1; i++) {
// if (score1[i] > score1[i+1]) {
// int t = score1[i];
// score1[i] = score1[i+1];
// score1[i+1] = t;
// }
// }
// }
Arrays.sort(score1);
for(i=0;i<score1.length;i++){
System.out.println(score1[i]);
}
5.数组元素逆序输出
char[] charArray2 = {'a','c','u','b','e','p','f','z'};
//字符串可以看成是字符数组
String str = "abcefpuz";
System.out.println(charArray2.length);
System.out.println(charArray2);
Arrays.sort(charArray2);
System.out.println(charArray2);
for(int i = charArray2.length - 1; i >= 0; i--)
{
System.out.print(charArray2[i]);
}
6.定义一个字符串数组,查找某个字符串在数组中出现的次数
String[] array = {"zhangsan","lisi","wangwu","lisi"};
String name = "wangwu";
int count = 0;//count计数,数字num在数组中出现的次数
for(int i = 0; i < array.length; i++)
{
if(array[i].equals(name))
{
count++;
}
}
System.out.println(count);