蓝桥算法训练 奇变的字符串 JAVA

问题描述
  将一个字符串的奇数位(首位为第0位)取出,将其顺序弄反,再放回原字符串的原位置上。
  如字符串"abcdefg",奇数位为"bdf",顺序弄反后为"fdb",最后得到字符串"afcdebg"。
输入格式
  输入共一行,为一个字符串,字符串中无空格。
输出格式
  输出共一行,为一个字符串,即最后得到的字符串。
样例输入
abcdefg
样例输出
afcdebg
数据规模和约定
  字符串长度不超过255.

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		String string = scanner.next();
		char str[] = string.toCharArray();
		int k = string.length() - 1;
		if (k % 2 == 0) {            // 保证k是倒数第一个奇数位
			k--;
		}
		char t;
		for (int i = 1; i < string.length() / 2; i += 2, k -= 2) { // i和k分别是正数和倒数得第一个,第一个奇数位同步到下一个
			if (i % 2 == 1) {                                      // 交换字符
				t = str[i];
				str[i] = str[k];
				str[k] = t;
			}
		}
		for (int i = 0; i < str.length; i++) {
			System.out.print(str[i]);
		}
	}
}

小剧场:我走的很慢,但从不后退。

发布了108 篇原创文章 · 获赞 113 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_43771695/article/details/104654206