首页 > 其他分享 >冒泡排序的习题全集(含答案)

冒泡排序的习题全集(含答案)

时间:2024-03-27 14:30:14浏览次数:17  
标签:arr Scanner int System 冒泡排序 含答案 new 习题 public

习题1

1.给定一个包含红色,白色和蓝色,共n个元素的数组nums,原地对他们进行排序,使得相同颜色的元素相邻,并按照共色,白色,蓝色顺序排列。

我们使用整数0,1,2分别表示红色,白色,蓝色

package maopao;
import java.util.*;
public class chapter1 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner scan=new Scanner(System.in);
		int n=scan.nextInt();
		int []nums=new int[n];
		for(int i=0;i<n;i++) {
			nums[i]=scan.nextInt();
		}
		
		
		for(int i=1;i<n;i++) {
			for(int j=0;j<n-i;j++) {
				if(nums[j]>nums[j+1]) {
					int tmp=nums[j+1];
					nums[j+1]=nums[j];
					nums[j]=tmp;
				}
			}
		}
		for(int i:nums) {
			System.out.print(i+" ");
		}
		Set<Integer> set=new HashSet<>();
		
		for(int i=0;i<n;i++) {
			set.add(nums[i]);
		
		}
		System.out.println("");
		for(int i:set) {
			System.out.print(i+" ");
		}
		
		
		
	}

}

习题2

有一个长度为7的无序数组,按照从小到大的顺序排序后输出

输入描述

数组中的数据

输出描述

数组中数据排序后的输出

示例

输入 13 11 9 7 5 3 1

输出 1 3 5 7 9 11 13

 第一种办法是利用Arrays.sort完成升序

package maopao;
import java.util.*;

public class chapter2 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		Scanner scan=new Scanner(System.in);
		int []arr=new int[7];
		for(int i=0;i<7;i++) {
			arr[i]=scan.nextInt();
		}
		Arrays.sort(arr);
		System.out.print("从小到大排序为:");
		for(int i:arr) {
			System.out.print(i+" ");
		}
	}

}

第二种办法是依赖于冒泡排序

package maopao;
import java.util.*;

public class chapter2 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		Scanner scan=new Scanner(System.in);
		int []arr=new int[7];
		for(int i=0;i<7;i++) {
			arr[i]=scan.nextInt();
		}
		for(int i=1;i<7;i++) {
			//次数
			for(int j=0;j<7-i;j++) {
				//数组
				if(arr[j]>arr[j+1]) {
					int tmp=arr[j+1];
					arr[j+1]=arr[j];
					arr[j]=tmp;
				}
			}
		}
		
		for(int i:arr) {
			System.out.print(i+" ");
		}
	}

}

习题3

 愚人节,灰太狼为了给红太狼惊喜,研发了羊羊打印仪,能够利用青草打印小羊们的模样,于是,灰太狼历经磨难,取来了喜羊羊  懒洋洋  美羊羊  沸羊羊  暖洋洋的毛发。利用这些毛发,他们打印出了羊羊们,叫来红太狼,红太狼很高兴,认为最肥美的杨应该先使用,就和灰太狼善良这从肥到瘦的顺序开始吃,请你设计一个算法,随机输入小羊的体重,并按降序将其输出。

package maopao;
import java.util.*;

public class chapter2 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		Scanner scan=new Scanner(System.in);
		int n=scan.nextInt();
		int []arr=new int[n];
		for(int i=0;i<n;i++) {
			arr[i]=scan.nextInt();
		}
		for(int i=1;i<n;i++) {
			//次数
			for(int j=0;j<n-i;j++) {
				//数组
				if(arr[j]<arr[j+1]) {
					int tmp=arr[j+1];
					arr[j+1]=arr[j];
					arr[j]=tmp;
				}
			}
		}

		for(int i:arr) {
			System.out.print(i+" ");
		}
	}

}

习题4

案例描述:一组数据中记录了五只小猪的体重,找出并打印最重的小猪
package maopao;
import java.util.*;
public class chapter4 {
	public static void main(String args[]) {
		Scanner scan=new Scanner(System.in);
		int n=scan.nextInt();
		int []arr=new int[n];
		for(int i=0;i<n;i++) {
			arr[i]=scan.nextInt();
		}
		for(int i=1;i<n;i++) {
			for(int j=0;j<n-i;j++) {
				if(arr[j]>arr[j+1]) {
					int tmp=arr[j+1];
					arr[j+1]=arr[j];
					arr[j]=tmp;
				}
			}
		}
		System.out.println(arr[n-1]);//数组下标是从0开始到n-1总共n个值
	}
}

标签:arr,Scanner,int,System,冒泡排序,含答案,new,习题,public
From: https://blog.csdn.net/weixin_62944148/article/details/137057588

相关文章

  • 30道Python基础练习题
    大家好,我是程序媛学姐,今天为大家梳理了30道Python基础练习题,方便大家学习参考。1.编写一个程序,输出"Hello,World!"这个程序的目标是简单地输出一条消息,即"Hello,World!"。在Python中,可以使用print语句来实现这个功能。示例代码:#输出"Hello,World!"print("Hello,......
  • 蓝桥杯练习题总结(三)线性dp题(摆花、数字三角形加强版)
    目录 一、摆花思路一: 确定状态:初始化:思路二:确定状态:初始化:循环遍历: 状态转移方程: 二、数字三角形加强版一、摆花题目描述小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆。通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号。为了......
  • 蓝桥杯练习题——博弈论
    1.必胜态后继至少存在一个必败态2.必败态后继均为必胜态Nim游戏思路23,先手必赢,先拿1,然后变成22,不管后手怎么拿,先手同样操作,后手一定先遇到00a1^a2^a3…^an=0,先手必败,否则先手必胜#include<iostream>usingnamespacestd;constintN=1e5+1......
  • 第九章总练习题
    赫尔曼·阿曼杜斯·施瓦茨大学初期攻读化学,在魏尔斯特拉斯等人的建议下改攻读数学。施瓦茨在哈雷、哥廷根和柏林工作,范围涉及函数论、微分几何和变分学。以他为名的有柯西-施瓦茨不等式、施瓦茨导数、施瓦茨-克里斯托费尔映射、施瓦茨反射原理和施瓦茨引理。 施瓦茨,即德国数学......
  • 软件工程与实践(第四版 新形态)第3章习题答案详解
    第三章一、填空题二、选择题三、简答题四、实践题一、填空题(1)方法或服务(2)类对象(3)类对象继承消息通信二、选择题(1)B(2)C(3)C(4)B(5)D三、简答题(1)什么叫面向对象?面向对象方法OOM的特点是什么?为什么用OOM开发软件?面向对象是一种软件开发方法,它将数据和操作数据的......
  • Scala函数练习题
    1、定义一个高阶函数,按照指定的规则对集合里面的每个元素进行操作比如:Array(“hh”,“red”,“java”,“hadoop”)规则:对集合中每个元素进行操作,得到集合每个元素的长度objecttest{defmain(args:Array[String]):Unit={vallist=Array("hh","red","ja......
  • Scala练习题
    1、定义一个高阶函数,按照指定的规则对集合里面的每个元素进行操作比如:Array(“hh”,“red”,“java”,“hadoop”)规则:对集合中每个元素进行操作,得到集合每个元素的长度packageljobjectaaa{defmain(args:Array[String]):Unit={vallist=Array("......
  • 习题4-11 兔子繁衍问题
    探索--题目集索引一对兔子,从出生后第3个月起每个月都生一对兔子。小兔子长到第3个月后每个月又生一对兔子。假如兔子都不死,请问第1个月出生的一对兔子,至少需要繁衍到第几个月时兔子总数才可以达到N对?输入格式:输入在一行中给出一个不超过10000的正整数N。输出格式:在一行......
  • AcWing基础语法课第二讲习题
    第二讲判断语句665.倍数#include<iostream>usingnamespacestd;intmain(){inta,b;cin>>a>>b;if(a%b==0||b%a==0)cout<<"SaoMultiplos"<<endl;elsecout<<"NaosaoMul......
  • PTA基础编程练习题目集 7—4 BCD解密
    题目描述:BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。所以如果一个BCD数的十六进制是0x12,它表达的就是十进制的12。但是小明没学过BCD,把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了!现在,你的程序要读入这个错误的十进......