LeetCode|Anagrams

题目

Given an array of strings, return all groups of strings that are anagrams.

Note: All inputs will be in lower-case.


思路

这个题目是判断所给的字符串数组中是否存在重复的颠倒字符串.

解决思路如下

首先为每个字符串排序   -->这个是用来判断是否存在重复的颠倒字符串

然后在为字符串数组排序  -->这个是用来使整个字符串数组都有序

这样下来就容易判断了

我用了一个 AnagramsNode 来保存当前字符串所在的位置,方便最后的输出

好了,题目解决

代码

class AnagramsNode implements Comparable<AnagramsNode>
{
	int index;
	String value;
	@Override
	public int compareTo(AnagramsNode o)
	{
		return value.compareTo(o.value);
	}
}
public class Solution {
    public ArrayList<String> anagrams(String[] strs) {
        ArrayList<String> result = new ArrayList<String>();
        ArrayList<AnagramsNode> node = new ArrayList<AnagramsNode>();

        for(int i =0; i <strs.length;i++)
        {
        	char[] temp = strs[i].toCharArray();
        	Arrays.sort(temp);
        	AnagramsNode anagramsNode = new AnagramsNode();
        	anagramsNode.index = i;
        	anagramsNode.value = String.copyValueOf(temp);
        	node.add(anagramsNode);
        }
        Collections.sort(node);
        for(int i = 0 ;i < strs.length; i++)
        {
        	AnagramsNode anagramsNode = node.get(i);
        	int j = i+1;
        	boolean flag = false;
        	for(;j<strs.length;j++)
        	{
        		if(node.get(j).value.equals(anagramsNode.value))
        		{
        			result.add(strs[node.get(j).index]);
        			flag = true;
        		}
        		else
        		{
        			j--;
        			break;
        		}
        		
        	}
        	if(flag == true)
        	{
        		i = j;
        		result.add(strs[anagramsNode.index]);
        	}
        }
        
        return result;
    }
}



### 如何在 IntelliJ IDEA 中配置和使用 Swagger #### 添加 Maven 依赖 为了使 Swagger 能够工作,在 `pom.xml` 文件中需加入特定的依赖项。这可以通过编辑项目的构建文件来完成: ```xml <dependencies> <!-- swagger2 --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.8.0</version> </dependency> <!-- swagger ui --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.8.0</version> </dependency> </dependencies> ``` 这些依赖会引入必要的库用于生成 API 文档以及提供交互式的 UI 页面[^4]。 #### 创建 Swagger 配置类 接着创建一个新的 Java 类用来初始化并配置 Swagger 实例。通常命名为类似于 `SwaggerConfig.java` 的名称,并放置于合适的位置,比如 `config` 包内: ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import springfox.documentation.builders.ApiInfoBuilder; import springfox.documentation.service.ApiInfo; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; @Configuration public class SwaggerConfig { @Bean public Docket api() { return new Docket(DocumentationType.SWAGGER_2) .apiInfo(apiInfo()) .select() .build(); } private ApiInfo apiInfo(){ return new ApiInfoBuilder().title("API文档").description("").termsOfServiceUrl("") .contact(new Contact("", "", "")) .license("").licenseUrl("").version("1.0") .build(); } } ``` 这段代码定义了一个 Spring Bean 来设置 Swagger 的基本信息和其他选项。 #### 启动应用测试 当上述步骤完成后,启动应用程序即可访问默认路径 `/swagger-ui.html` 查看自动生成的 RESTful 接口文档界面。通过浏览器打开该链接可以浏览到所有已暴露出来的 HTTP 请求方法及其参数说明等信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值