【Java每日编程小练习 2021-01-19】 输入n个字符串,降序排列后,按照{x,y,z}格式输出

该博客介绍了如何使用Java实现一个编程练习,即接收n个字符串,按照降序排列后,以{x, y, z}格式输出。博主详细分析了题目,提出了冒泡排序的解决方案,并提供了三种不同的代码实现方式,包括使用for循环拼接和StringJoiner类的方法。" 38469315,2854367,使用OpenCV读取与转换视频帧,"['OpenCV', '视频处理', '图像处理']
摘要由CSDN通过智能技术生成

1 题目重述

题目描述:输入n个字符串,降序排列后,按照{x,y,z}格式输出
例如:

  • 输入:3
  • 输入:AK,AS,AC
  • 输出:{AC,AK,AS}

2 题目分析

2.1题目梳理

题目中的关键字:输入,字符串,降序排列,格式输出

今天的题目需要我们获取两个类型内容,一个是整型,一个是字符串。
于是我们分别采用 Scanner 类的 nextInt() 方法和 next() 方法对两个内容进行获取,并分别保存在整型 n 和字符串 str 中。

下面我们就要思考如何实现数组的降序排列。我们需要将数组中的每一个元素两两进行比较,谁大谁就排在前面。我们可以采用冒泡排序算法对字符串数组进行排序。

最后,我们需要思考如何按照指定格式输出字符串。我们可以采用System.out.print() 方法对字符串进行字符串首尾指定字符的拼接工作,同时通过 for 循环遍历每一个元素,并在元素后加上指定的字符。

这个过程听起来十分复杂,那么有没有更好的实现方法呢?有的。Java 为我们提供了 StringJoiner 类的 joiner.add() 方法,可以对字符串按照一定格式进行拼接。我们可以通过创建 StringJoiner 类的对象来调用 StringJoiner 类的有参构造方法,以此来达到我们的需要。

2.2 实现思路

2.2.1 输入

采用 Scanner 类的 nextInt() 方法,获取一个整数 n 。
采用 Scanner 类的 next() 方法,获取一个字符串 str 。

2.2.2 对原字符串按照指定字符串“,”进行分割

采用 String 类的split()方法,将原字符串按照指定字符串进行分割,返回切割后的字符串数组。

2.2.3 判断字符串元素个数与输入个数 n 是否一致

先采用 if 语句进行字符串元素个数的判断,如果小于输入个数 n ,那么我们题目的条件就无法达成,为了避免这种情况,我们就需要对字符串元素个数与输入个数 n 是否一致这一问题进行判断。

此时,在字符串元素个数小于输入个数 n 的情况下,我们就需要返回 “输入有误!” ,同时退出JVM虚拟机,使得程序结束。

同样,为了避免输入字符串元素个数大于输入个数 n 。同时有效地保证,输入的字符串个数与输入个数 n 的一致性。我们采用 System.arraycopy() 方法,将数组按照指定要求进行复制。这样做的目的是,保证字符串元素个数与输入个数 n 一致。

2.2.4 倒序排列
思路:采用冒泡排序法的倒序排列方式对原字符串数组进行倒序排列。

冒泡排序算法是一种非常常用的算法,在这里和大家针对本题进行叙述。

冒泡排序算法(伪代码)

	BUBBLE-SORT(A)
1.	for i <--- 1
2.		do for j <--- length[A] downto i+1
3.			do if A[j] < A[j+1]
4.				then exchange A[j] <---> A[j+1]
分析

本题中,我们首先要知道比几轮,其次要知道每轮比较多少次。
第一个元素和第二个元素比较,再和第三个元素比较,以此类推… …,直到第一个元素和第 n 个元素比较;
第二个元素和第三个元素比较,再和第四个元素比较,以此类推… …,直到第二个元素和第 n 个元素比较;
以此类推 … …
直到,第 n-1 个元素和第 n 个元素进行比较。

我们用 n 代表元素个数,用 i 代表比较的轮数,用 k 代表每轮比较的次数。
我们发现共需要比较 n-1 轮,同时每轮比较 n-1-i 次。

由此,我们需要进行双重循环,外层循环控制比较的轮数,内层循环控制每轮比较的次数。同时,我们需要采用 String 类的 compareTo() 方法进行相邻元素大小的判断,满足要求保持位置不变,否则交换两个元素位置。

2.2.5 按指定格式输出

这里为大家提供了两种思路,供大家参考。

思路1:通过 for(){…} 循环遍历,直接拼接。

这种输出方式不需要我们多想,就你需要什么形式,我输出什么形式。但是在拼接的时候需要采用 for 循环对字符串进行遍历,同时我们发现输出格式中最后一个元素的后面没有 “,” ,因而,我们需要采用 if判断语句判断元素是否为最后一个元素,如果不是,拼接 “,” ,否则不拼接。

值得注意的是这里的输出采用的是 System.out.print("") 输出形式,只输出不换行。

思路2:采用 StringJoiner 类的 joiner.add() 方法,对字符串按照一定格式进行拼接。

我们思考,如果元素少采用第一种思路也没有什么问题,但是如果元素多了呢?或者元素要求复杂了呢?有没有一种更好的实现思路?

幸运的是,java 为我们提供了一个这样的类型 StringJoiner 类。我们可以通过创建 StringJoiner 类的对象来调用 StringJoiner 类的有参构造方法。

  • 采用 StringJoiner joiner=new StringJoiner(delimiter, prefix, suffix) ;的形式。
  • 功能:对字符串按一定要求进行连接。
  • 传入:字符串之间的间隔符,字符串最前面字符,字符串最后面字符
  • 返回:连接后的字符串

3 代码实现

3.1 方式1:

按指定格式输出:通过 System.out.print("") 和 for(){…} 循环遍历,直接拼接。

3.1.1 代码语句:
	public static void main(String[
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
可以使用C语言中的字符串数组和排序函数来实现输入n个字符串并按降序排列输出的功能。 具体步骤如下: 1. 定义一个字符串数组,用于存储输入的n个字符串。 2. 使用循环语句,依次输入n个字符串。 3. 使用C语言中的排序函数,对字符串数组进行降序排列。 4. 使用循环语句,依次输出排好序的字符串数组。 下面是一个示例代码: ```c #include <stdio.h> #include <string.h> #define MAX_STR_LEN 100 #define MAX_STR_NUM 10 int main() { char str[MAX_STR_NUM][MAX_STR_LEN]; int i, j, n; printf("请输入字符串个数n:"); scanf("%d", &n); printf("请输入%d个字符串:\n", n); for (i = 0; i < n; i++) { scanf("%s", str[i]); } // 使用冒泡排序字符串数组进行降序排列 for (i = 0; i < n - 1; i++) { for (j = 0; j < n - i - 1; j++) { if (strcmp(str[j], str[j + 1]) < 0) { char temp[MAX_STR_LEN]; strcpy(temp, str[j]); strcpy(str[j], str[j + 1]); strcpy(str[j + 1], temp); } } } printf("降序排列后的字符串为:\n"); for (i = 0; i < n; i++) { printf("%s\n", str[i]); } return 0; } ``` 这段代码中,我们使用了冒泡排序字符串数组进行降序排列。在冒泡排序中,我们比较相邻的两个字符串,如果前一个字符串比后一个字符串小,则交换它们的位置。这样一轮比较下来,最大的字符串就会被排到最后面。重复这个过程,直到所有的字符串都被排好序。 最后,我们使用循环语句依次输出排好序的字符串数组,即可完成输入n个字符串并按降序排列输出的功能。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值