-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathLeftRotateString.cs
85 lines (73 loc) · 2.66 KB
/
LeftRotateString.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
题目名称:
左旋转字符串
题目描述:
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。
对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。
例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!
代码结构:
class Solution
{
public string LeftRotateString(string str, int n)
{
// write code here
}
}
*/
using System;
namespace LeftRotateString {
class Solution {
/// <summary>
/// 解法1
/// 基本思路:
/// 利用对字符串的长度求余,处理左移位数大于字符串长度的情况
/// 小于字符串长度的左移,通过分割字符串后调转位置得到
/// </summary>
public string LeftRotateString(string str, int n)
{
if(str == null || str.Length == 0){
return str;
}
int index = n % str.Length;
char[] array = str.ToCharArray();
return new string(array, index, str.Length - index) + new string(array, 0, index);
}
/// <summary>
/// 解法2
/// 基本思路:
/// 同样利用对字符串的长度求余,处理左移位数大于字符串长度的情况
/// 对于小于字符串长度的左移,利用 XY的翻转 = YX = (X的翻转 + Y的翻转)的翻转 得到
/// </summary>
public void Reverse(char[] array, int i, int j){
for(int m = i, n = j; m < n; m ++, n --){
char temp = array[m];
array[m] = array[n];
array[n] = temp;
}
}
public string LeftRotateString2(string str, int n)
{
if(str == null || str.Length == 0){
return str;
}
int index = n % str.Length;
char[] array = str.ToCharArray();
Reverse(array, 0, index - 1);
Reverse(array, index, array.Length - 1);
Reverse(array, 0, array.Length - 1);
return new string(array);
}
public void Test() {
string str = "abcXYZdef";
// str = null;
// str = "";
int n = 3;
// n = 0;
// n = 1;
// n = 9;
// n = 10;
Console.WriteLine(LeftRotateString(str, n));
// Console.WriteLine(LeftRotateString2(str, n));
}
}
}