Java递归算法——变位字

Java递归算法——变位字

Java递归算法——变位字

轮换的含义

1.c ats --> 2.ca st

3.c tsa --> 4.ct as

5.c sat --> 6.cs ta

7. atsc

 

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

//=================================================
// File Name       :	Anagram_demo
//------------------------------------------------------------------------------
// Author          :	Common

//类名:BinarySearch_Find
//属性:
//方法:



//主类
//Function        : 	Anagram_demo
public class Anagram_demo {
	
	static int Size;
	static int count=0;
	static char[] arrChar = new char[100];
	
	public static void main(String[] args) throws Exception{
		// TODO 自动生成的方法存根
		System.out.println("请输入一个单词:");
		String input = getString();
		Size = input.length();
		for(int i=0;i<Size;i++){
			arrChar[i] = input.charAt(i);
		}
		doAnagram(Size);
	}
	
	public static void doAnagram(int newSize){
		if(newSize == 1)		//只有一个就不做任何处理
			return;
		for(int i=0;i<newSize;i++){
			doAnagram(newSize - 1);
			if(newSize == 2){
				displayWord();
			}
			rorate(newSize);
		}
	}
	
	public static void displayWord(){
		System.out.print(++count);
		for(int i=0;i<Size;i++){
			System.out.print(arrChar[i]);
		}
		System.out.println("、");
	}
	
	public static void rorate(int newSize){		//轮换函数
		
		int position = Size - newSize;
		char temp = arrChar[position];
		for(int i=position;i<Size-1;i++){
			arrChar[i] = arrChar[i+1];
		}
		arrChar[Size-1] = temp;
	}
	
	//输出方法
			public static String getString() throws IOException{
				InputStreamReader isr = new InputStreamReader(System.in);
				BufferedReader br = new BufferedReader(isr);
				String s = br.readLine();
				return s;
			}
			
			//输出方法
			public static int getInt() throws IOException{
				String s = getString();
				return Integer.parseInt(s);
				
			}

}

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-08-03
  • 2021-09-23
猜你喜欢
  • 2021-06-07
  • 2022-12-23
  • 2021-09-22
  • 2021-07-19
  • 2022-12-23
相关资源
相似解决方案