Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Commit19e7a1b

Browse files
add a solution for 34
1 parentd376196 commit19e7a1b

File tree

2 files changed

+82
-40
lines changed

2 files changed

+82
-40
lines changed

‎src/main/java/com/fishercoder/solutions/_34.java

Lines changed: 74 additions & 36 deletions
Original file line numberDiff line numberDiff line change
@@ -2,49 +2,87 @@
22

33
publicclass_34 {
44

5-
publicint[]searchRange(int[]nums,inttarget) {
6-
int[]range =newint[2];
7-
range[0] = -1;
8-
range[1] = -1;
9-
if (nums ==null ||nums.length ==0) {
10-
returnrange;
11-
}
12-
intstart =0;
13-
intend =nums.length -1;
14-
while (start +1 <end) {
15-
intmid =start + (end -start) /2;
16-
if (nums[mid] ==target) {
17-
intleft =mid;
18-
while (left -1 >=0 &&nums[left] ==nums[left -1]) {
19-
left--;
5+
publicstaticclassSolution1 {
6+
publicint[]searchRange(int[]nums,inttarget) {
7+
int[]range =newint[2];
8+
range[0] = -1;
9+
range[1] = -1;
10+
if (nums ==null ||nums.length ==0) {
11+
returnrange;
12+
}
13+
intstart =0;
14+
intend =nums.length -1;
15+
while (start +1 <end) {
16+
intmid =start + (end -start) /2;
17+
if (nums[mid] ==target) {
18+
intleft =mid;
19+
while (left -1 >=0 &&nums[left] ==nums[left -1]) {
20+
left--;
21+
}
22+
range[0] =left;
23+
intright =mid;
24+
while (right +1 <nums.length &&nums[right] ==nums[right +1]) {
25+
right++;
26+
}
27+
range[1] =right;
28+
break;
29+
}elseif (nums[mid] <target) {
30+
start =mid;
31+
}else {
32+
end =mid;
33+
}
34+
}
35+
36+
if (nums[start] ==target) {
37+
range[0] =start;
38+
while (start +1 <nums.length &&nums[start] ==nums[start +1]) {
39+
start++;
2040
}
21-
range[0] =left;
22-
intright =mid;
23-
while (right +1 <nums.length &&nums[right] ==nums[right +1]) {
24-
right++;
41+
range[1] =start;
42+
}elseif (nums[end] ==target) {
43+
range[1] =end;
44+
while (end -1 >=0 &&nums[end] ==nums[end -1]) {
45+
end--;
2546
}
26-
range[1] =right;
27-
break;
28-
}elseif (nums[mid] <target) {
29-
start =mid;
30-
}else {
31-
end =mid;
47+
range[0] =end;
3248
}
49+
returnrange;
3350
}
51+
}
3452

35-
if (nums[start] ==target) {
36-
range[0] =start;
37-
while (start +1 <nums.length &&nums[start] ==nums[start +1]) {
38-
start++;
53+
publicstaticclassSolution2 {
54+
publicint[]searchRange(int[]nums,inttarget) {
55+
int[]result =newint[]{-1, -1};
56+
if (nums ==null ||nums.length ==0) {
57+
returnresult;
58+
}
59+
if (nums[0] >target) {
60+
returnresult;
3961
}
40-
range[1] =start;
41-
}elseif (nums[end] ==target) {
42-
range[1] =end;
43-
while (end -1 >=0 &&nums[end] ==nums[end -1]) {
44-
end--;
62+
if (nums[nums.length -1] <target) {
63+
returnresult;
64+
}
65+
intleft =0;
66+
intright =nums.length -1;
67+
while (left <=right) {
68+
intmid =left + (right -left) /2;
69+
if (nums[mid] ==target) {
70+
while (mid -1 >=0 &&nums[mid] ==nums[mid -1]) {
71+
mid--;
72+
}
73+
result[0] =mid;
74+
while (mid +1 <nums.length &&nums[mid] ==nums[mid +1]) {
75+
mid++;
76+
}
77+
result[1] =mid;
78+
returnresult;
79+
}elseif (nums[mid] >target) {
80+
right =mid -1;
81+
}else {
82+
left =mid +1;
83+
}
4584
}
46-
range[0] =end;
85+
returnresult;
4786
}
48-
returnrange;
4987
}
5088
}

‎src/test/java/com/fishercoder/_34Test.java

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -7,23 +7,27 @@
77
importstaticorg.junit.Assert.assertArrayEquals;
88

99
publicclass_34Test {
10-
privatestatic_34test;
10+
privatestatic_34.Solution1solution1;
11+
privatestatic_34.Solution2solution2;
1112
privatestaticint[]nums;
1213

1314
@BeforeClass
1415
publicstaticvoidsetup() {
15-
test =new_34();
16+
solution1 =new_34.Solution1();
17+
solution2 =new_34.Solution2();
1618
}
1719

1820
@Test
1921
publicvoidtest1() {
2022
nums =newint[]{1,2,3};
21-
assertArrayEquals(newint[]{1,1},test.searchRange(nums,2));
23+
assertArrayEquals(newint[]{1,1},solution1.searchRange(nums,2));
24+
assertArrayEquals(newint[]{1,1},solution2.searchRange(nums,2));
2225
}
2326

2427
@Test
2528
publicvoidtest2() {
2629
nums =newint[]{};
27-
assertArrayEquals(newint[]{-1, -1},test.searchRange(nums,0));
30+
assertArrayEquals(newint[]{-1, -1},solution1.searchRange(nums,0));
31+
assertArrayEquals(newint[]{-1, -1},solution2.searchRange(nums,0));
2832
}
2933
}

0 commit comments

Comments
 (0)

[8]ページ先頭

©2009-2025 Movatter.jp