Find the smallest positive number missing from an unsorted array
up vote
5
down vote
favorite
this is the original question
https://www.geeksforgeeks.org/find-the-smallest-positive-number-missing-from-an-unsorted-array/
You are given an unsorted array with both positive and negative elements. You have to find the smallest positive number missing from the array in O(n) time using constant extra space. You can modify the original array.
Input: {2, 3, 7, 6, 8, -1, -10, 15} Output: 1
Input: { 2, 3, -7, 6, 8, 1, -10, 15 } Output: 4
Input: {1, 1, 0, -1, -2} Output: 2
using System;
using System.Collections.Generic;
using Microsoft.VisualStudio.TestTools.UnitTesting;
namespace ArrayQuestions
{
[TestClass]
public class FindTheSmallestNonnegativeNumberNoyInArray
{
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest()
{
int array = {2, 3, 7, 6, 8, -1, -10, 15};
int result = FindSmallestPositiveHash(array);
int expected = 1;
Assert.AreEqual(expected, result);
}
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest2()
{
int array = { 2, 3, -7, 6, 8, 1, -10, 15 };
int result = FindSmallestPositiveHash(array);
int expected = 4;
Assert.AreEqual(expected, result);
}
private int FindSmallestPositiveHash(int array)
{
HashSet<int> set = new HashSet<int>();
int maxPositive = 0;
for (int i = 0; i < array.Length; i++)
{
if (!set.Contains(array[i]))
{
maxPositive = Math.Max(maxPositive, array[i]);
set.Add(array[i]);
}
}
for (int i = 1; i < maxPositive; i++)
{
if (!set.Contains(i))
{
return i;
}
}
return maxPositive + 1;
}
}
}
I know there is a better solution, I tried to implement the hash based solution please comment or runtime and performance.
Thanks
c# programming-challenge interview-questions
add a comment |
up vote
5
down vote
favorite
this is the original question
https://www.geeksforgeeks.org/find-the-smallest-positive-number-missing-from-an-unsorted-array/
You are given an unsorted array with both positive and negative elements. You have to find the smallest positive number missing from the array in O(n) time using constant extra space. You can modify the original array.
Input: {2, 3, 7, 6, 8, -1, -10, 15} Output: 1
Input: { 2, 3, -7, 6, 8, 1, -10, 15 } Output: 4
Input: {1, 1, 0, -1, -2} Output: 2
using System;
using System.Collections.Generic;
using Microsoft.VisualStudio.TestTools.UnitTesting;
namespace ArrayQuestions
{
[TestClass]
public class FindTheSmallestNonnegativeNumberNoyInArray
{
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest()
{
int array = {2, 3, 7, 6, 8, -1, -10, 15};
int result = FindSmallestPositiveHash(array);
int expected = 1;
Assert.AreEqual(expected, result);
}
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest2()
{
int array = { 2, 3, -7, 6, 8, 1, -10, 15 };
int result = FindSmallestPositiveHash(array);
int expected = 4;
Assert.AreEqual(expected, result);
}
private int FindSmallestPositiveHash(int array)
{
HashSet<int> set = new HashSet<int>();
int maxPositive = 0;
for (int i = 0; i < array.Length; i++)
{
if (!set.Contains(array[i]))
{
maxPositive = Math.Max(maxPositive, array[i]);
set.Add(array[i]);
}
}
for (int i = 1; i < maxPositive; i++)
{
if (!set.Contains(i))
{
return i;
}
}
return maxPositive + 1;
}
}
}
I know there is a better solution, I tried to implement the hash based solution please comment or runtime and performance.
Thanks
c# programming-challenge interview-questions
add a comment |
up vote
5
down vote
favorite
up vote
5
down vote
favorite
this is the original question
https://www.geeksforgeeks.org/find-the-smallest-positive-number-missing-from-an-unsorted-array/
You are given an unsorted array with both positive and negative elements. You have to find the smallest positive number missing from the array in O(n) time using constant extra space. You can modify the original array.
Input: {2, 3, 7, 6, 8, -1, -10, 15} Output: 1
Input: { 2, 3, -7, 6, 8, 1, -10, 15 } Output: 4
Input: {1, 1, 0, -1, -2} Output: 2
using System;
using System.Collections.Generic;
using Microsoft.VisualStudio.TestTools.UnitTesting;
namespace ArrayQuestions
{
[TestClass]
public class FindTheSmallestNonnegativeNumberNoyInArray
{
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest()
{
int array = {2, 3, 7, 6, 8, -1, -10, 15};
int result = FindSmallestPositiveHash(array);
int expected = 1;
Assert.AreEqual(expected, result);
}
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest2()
{
int array = { 2, 3, -7, 6, 8, 1, -10, 15 };
int result = FindSmallestPositiveHash(array);
int expected = 4;
Assert.AreEqual(expected, result);
}
private int FindSmallestPositiveHash(int array)
{
HashSet<int> set = new HashSet<int>();
int maxPositive = 0;
for (int i = 0; i < array.Length; i++)
{
if (!set.Contains(array[i]))
{
maxPositive = Math.Max(maxPositive, array[i]);
set.Add(array[i]);
}
}
for (int i = 1; i < maxPositive; i++)
{
if (!set.Contains(i))
{
return i;
}
}
return maxPositive + 1;
}
}
}
I know there is a better solution, I tried to implement the hash based solution please comment or runtime and performance.
Thanks
c# programming-challenge interview-questions
this is the original question
https://www.geeksforgeeks.org/find-the-smallest-positive-number-missing-from-an-unsorted-array/
You are given an unsorted array with both positive and negative elements. You have to find the smallest positive number missing from the array in O(n) time using constant extra space. You can modify the original array.
Input: {2, 3, 7, 6, 8, -1, -10, 15} Output: 1
Input: { 2, 3, -7, 6, 8, 1, -10, 15 } Output: 4
Input: {1, 1, 0, -1, -2} Output: 2
using System;
using System.Collections.Generic;
using Microsoft.VisualStudio.TestTools.UnitTesting;
namespace ArrayQuestions
{
[TestClass]
public class FindTheSmallestNonnegativeNumberNoyInArray
{
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest()
{
int array = {2, 3, 7, 6, 8, -1, -10, 15};
int result = FindSmallestPositiveHash(array);
int expected = 1;
Assert.AreEqual(expected, result);
}
[TestMethod]
public void FindTheSmallestNonnegativeNumberNoyInArrayTest2()
{
int array = { 2, 3, -7, 6, 8, 1, -10, 15 };
int result = FindSmallestPositiveHash(array);
int expected = 4;
Assert.AreEqual(expected, result);
}
private int FindSmallestPositiveHash(int array)
{
HashSet<int> set = new HashSet<int>();
int maxPositive = 0;
for (int i = 0; i < array.Length; i++)
{
if (!set.Contains(array[i]))
{
maxPositive = Math.Max(maxPositive, array[i]);
set.Add(array[i]);
}
}
for (int i = 1; i < maxPositive; i++)
{
if (!set.Contains(i))
{
return i;
}
}
return maxPositive + 1;
}
}
}
I know there is a better solution, I tried to implement the hash based solution please comment or runtime and performance.
Thanks
c# programming-challenge interview-questions
c# programming-challenge interview-questions
edited Nov 22 at 15:46
t3chb0t
33.7k746110
33.7k746110
asked Nov 22 at 9:22
Gilad
1,25431526
1,25431526
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
up vote
7
down vote
accepted
There are a few things you can do to simplify your code:
- There's no need to keep track of the maximum positive integer if you remove the condition from the second
for
loop:for (int i = 1; ; i++)
. - That means you don't need to check whether the hash already contains the given number: just add it right away.
- If you don't mind a small performance hit you can use Linq's
ToHashSet
instead:var set = array.ToHashSet();
(Edit: ornew HashSet<int>(array);
if you're not using .NET Framework 4.7.2).
Edit: Alternately, if you expect a lot of negative values in your inputs, not adding those to the set can result in a fair speed improvement - I'm seeing a 30% improvement for inputs with 50% negative values.
The first three changes don't really speed things up, and the last one is fairly input-specific. For a significant and more reliable performance improvement, replace the hash with an array of booleans:
var presence = new bool[array.Length + 1];
foreach (var value in array)
{
if (value > 0 && value < presence.Length)
{
presence[value] = true;
}
}
for (int i = 1; i < presence.Length; i++)
{
if (!presence[i])
{
return i;
}
}
return presence.Length;
The maximum possible return value is array.Length + 1
, so values larger than that can safely be ignored (just like negative values) because they won't affect the result. The input [1, 2, 3]
produces 4
. Replacing any of these numbers with a larger one will create a gap: [1, 99, 3]
produces 2
. Whether or not 99
is present is irrelevant: what matters is that 2
is not present.
For large inputs this is about twice as fast, for small inputs it can be more than 10x faster. Hash set lookups are fast, but there is some overhead involved, so they won't beat array lookups.
Edit: The proposed solution on their website is (re)using the input array as a lookup table. It's moving all positive numbers to the front and then marking the presence of numbers by making the value at that index negative - somewhat similar to the above approach. I guess the first step allows them to simplify the rest of the algorithm, but it does make things slower. That first step can be removed with careful swapping and negating, making it run faster, but it's still a bit slower as the array of boolean approach - and more difficult to understand.
1
.NET Framework 4.7.2
- that's why I've never seenToHashSet
before :-o I was wondering what you are talking about ;-)
– t3chb0t
Nov 22 at 15:49
@pieter, what is the space complexity of your solution? Can you please explain? I think it is O(n). Is it right?
– Emdad
Nov 25 at 9:39
@Emdad: it takes O(n) space, yes.
– Pieter Witvoet
Nov 25 at 14:14
@PieterWitvoet, thanks for your clarification. I am looking for O(1) space complexity for this problem. Can you please help me?
– Emdad
Nov 25 at 16:12
1
@Emdad: the last part of my post contains some notes about the O(1) solution that is shown on the website Gilad linked to. It's more complicated, slower and requires modifications to the input, so I don't see much practical use for it.
– Pieter Witvoet
Nov 25 at 19:32
add a comment |
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
7
down vote
accepted
There are a few things you can do to simplify your code:
- There's no need to keep track of the maximum positive integer if you remove the condition from the second
for
loop:for (int i = 1; ; i++)
. - That means you don't need to check whether the hash already contains the given number: just add it right away.
- If you don't mind a small performance hit you can use Linq's
ToHashSet
instead:var set = array.ToHashSet();
(Edit: ornew HashSet<int>(array);
if you're not using .NET Framework 4.7.2).
Edit: Alternately, if you expect a lot of negative values in your inputs, not adding those to the set can result in a fair speed improvement - I'm seeing a 30% improvement for inputs with 50% negative values.
The first three changes don't really speed things up, and the last one is fairly input-specific. For a significant and more reliable performance improvement, replace the hash with an array of booleans:
var presence = new bool[array.Length + 1];
foreach (var value in array)
{
if (value > 0 && value < presence.Length)
{
presence[value] = true;
}
}
for (int i = 1; i < presence.Length; i++)
{
if (!presence[i])
{
return i;
}
}
return presence.Length;
The maximum possible return value is array.Length + 1
, so values larger than that can safely be ignored (just like negative values) because they won't affect the result. The input [1, 2, 3]
produces 4
. Replacing any of these numbers with a larger one will create a gap: [1, 99, 3]
produces 2
. Whether or not 99
is present is irrelevant: what matters is that 2
is not present.
For large inputs this is about twice as fast, for small inputs it can be more than 10x faster. Hash set lookups are fast, but there is some overhead involved, so they won't beat array lookups.
Edit: The proposed solution on their website is (re)using the input array as a lookup table. It's moving all positive numbers to the front and then marking the presence of numbers by making the value at that index negative - somewhat similar to the above approach. I guess the first step allows them to simplify the rest of the algorithm, but it does make things slower. That first step can be removed with careful swapping and negating, making it run faster, but it's still a bit slower as the array of boolean approach - and more difficult to understand.
1
.NET Framework 4.7.2
- that's why I've never seenToHashSet
before :-o I was wondering what you are talking about ;-)
– t3chb0t
Nov 22 at 15:49
@pieter, what is the space complexity of your solution? Can you please explain? I think it is O(n). Is it right?
– Emdad
Nov 25 at 9:39
@Emdad: it takes O(n) space, yes.
– Pieter Witvoet
Nov 25 at 14:14
@PieterWitvoet, thanks for your clarification. I am looking for O(1) space complexity for this problem. Can you please help me?
– Emdad
Nov 25 at 16:12
1
@Emdad: the last part of my post contains some notes about the O(1) solution that is shown on the website Gilad linked to. It's more complicated, slower and requires modifications to the input, so I don't see much practical use for it.
– Pieter Witvoet
Nov 25 at 19:32
add a comment |
up vote
7
down vote
accepted
There are a few things you can do to simplify your code:
- There's no need to keep track of the maximum positive integer if you remove the condition from the second
for
loop:for (int i = 1; ; i++)
. - That means you don't need to check whether the hash already contains the given number: just add it right away.
- If you don't mind a small performance hit you can use Linq's
ToHashSet
instead:var set = array.ToHashSet();
(Edit: ornew HashSet<int>(array);
if you're not using .NET Framework 4.7.2).
Edit: Alternately, if you expect a lot of negative values in your inputs, not adding those to the set can result in a fair speed improvement - I'm seeing a 30% improvement for inputs with 50% negative values.
The first three changes don't really speed things up, and the last one is fairly input-specific. For a significant and more reliable performance improvement, replace the hash with an array of booleans:
var presence = new bool[array.Length + 1];
foreach (var value in array)
{
if (value > 0 && value < presence.Length)
{
presence[value] = true;
}
}
for (int i = 1; i < presence.Length; i++)
{
if (!presence[i])
{
return i;
}
}
return presence.Length;
The maximum possible return value is array.Length + 1
, so values larger than that can safely be ignored (just like negative values) because they won't affect the result. The input [1, 2, 3]
produces 4
. Replacing any of these numbers with a larger one will create a gap: [1, 99, 3]
produces 2
. Whether or not 99
is present is irrelevant: what matters is that 2
is not present.
For large inputs this is about twice as fast, for small inputs it can be more than 10x faster. Hash set lookups are fast, but there is some overhead involved, so they won't beat array lookups.
Edit: The proposed solution on their website is (re)using the input array as a lookup table. It's moving all positive numbers to the front and then marking the presence of numbers by making the value at that index negative - somewhat similar to the above approach. I guess the first step allows them to simplify the rest of the algorithm, but it does make things slower. That first step can be removed with careful swapping and negating, making it run faster, but it's still a bit slower as the array of boolean approach - and more difficult to understand.
1
.NET Framework 4.7.2
- that's why I've never seenToHashSet
before :-o I was wondering what you are talking about ;-)
– t3chb0t
Nov 22 at 15:49
@pieter, what is the space complexity of your solution? Can you please explain? I think it is O(n). Is it right?
– Emdad
Nov 25 at 9:39
@Emdad: it takes O(n) space, yes.
– Pieter Witvoet
Nov 25 at 14:14
@PieterWitvoet, thanks for your clarification. I am looking for O(1) space complexity for this problem. Can you please help me?
– Emdad
Nov 25 at 16:12
1
@Emdad: the last part of my post contains some notes about the O(1) solution that is shown on the website Gilad linked to. It's more complicated, slower and requires modifications to the input, so I don't see much practical use for it.
– Pieter Witvoet
Nov 25 at 19:32
add a comment |
up vote
7
down vote
accepted
up vote
7
down vote
accepted
There are a few things you can do to simplify your code:
- There's no need to keep track of the maximum positive integer if you remove the condition from the second
for
loop:for (int i = 1; ; i++)
. - That means you don't need to check whether the hash already contains the given number: just add it right away.
- If you don't mind a small performance hit you can use Linq's
ToHashSet
instead:var set = array.ToHashSet();
(Edit: ornew HashSet<int>(array);
if you're not using .NET Framework 4.7.2).
Edit: Alternately, if you expect a lot of negative values in your inputs, not adding those to the set can result in a fair speed improvement - I'm seeing a 30% improvement for inputs with 50% negative values.
The first three changes don't really speed things up, and the last one is fairly input-specific. For a significant and more reliable performance improvement, replace the hash with an array of booleans:
var presence = new bool[array.Length + 1];
foreach (var value in array)
{
if (value > 0 && value < presence.Length)
{
presence[value] = true;
}
}
for (int i = 1; i < presence.Length; i++)
{
if (!presence[i])
{
return i;
}
}
return presence.Length;
The maximum possible return value is array.Length + 1
, so values larger than that can safely be ignored (just like negative values) because they won't affect the result. The input [1, 2, 3]
produces 4
. Replacing any of these numbers with a larger one will create a gap: [1, 99, 3]
produces 2
. Whether or not 99
is present is irrelevant: what matters is that 2
is not present.
For large inputs this is about twice as fast, for small inputs it can be more than 10x faster. Hash set lookups are fast, but there is some overhead involved, so they won't beat array lookups.
Edit: The proposed solution on their website is (re)using the input array as a lookup table. It's moving all positive numbers to the front and then marking the presence of numbers by making the value at that index negative - somewhat similar to the above approach. I guess the first step allows them to simplify the rest of the algorithm, but it does make things slower. That first step can be removed with careful swapping and negating, making it run faster, but it's still a bit slower as the array of boolean approach - and more difficult to understand.
There are a few things you can do to simplify your code:
- There's no need to keep track of the maximum positive integer if you remove the condition from the second
for
loop:for (int i = 1; ; i++)
. - That means you don't need to check whether the hash already contains the given number: just add it right away.
- If you don't mind a small performance hit you can use Linq's
ToHashSet
instead:var set = array.ToHashSet();
(Edit: ornew HashSet<int>(array);
if you're not using .NET Framework 4.7.2).
Edit: Alternately, if you expect a lot of negative values in your inputs, not adding those to the set can result in a fair speed improvement - I'm seeing a 30% improvement for inputs with 50% negative values.
The first three changes don't really speed things up, and the last one is fairly input-specific. For a significant and more reliable performance improvement, replace the hash with an array of booleans:
var presence = new bool[array.Length + 1];
foreach (var value in array)
{
if (value > 0 && value < presence.Length)
{
presence[value] = true;
}
}
for (int i = 1; i < presence.Length; i++)
{
if (!presence[i])
{
return i;
}
}
return presence.Length;
The maximum possible return value is array.Length + 1
, so values larger than that can safely be ignored (just like negative values) because they won't affect the result. The input [1, 2, 3]
produces 4
. Replacing any of these numbers with a larger one will create a gap: [1, 99, 3]
produces 2
. Whether or not 99
is present is irrelevant: what matters is that 2
is not present.
For large inputs this is about twice as fast, for small inputs it can be more than 10x faster. Hash set lookups are fast, but there is some overhead involved, so they won't beat array lookups.
Edit: The proposed solution on their website is (re)using the input array as a lookup table. It's moving all positive numbers to the front and then marking the presence of numbers by making the value at that index negative - somewhat similar to the above approach. I guess the first step allows them to simplify the rest of the algorithm, but it does make things slower. That first step can be removed with careful swapping and negating, making it run faster, but it's still a bit slower as the array of boolean approach - and more difficult to understand.
edited Nov 22 at 18:25
answered Nov 22 at 11:02
Pieter Witvoet
5,486725
5,486725
1
.NET Framework 4.7.2
- that's why I've never seenToHashSet
before :-o I was wondering what you are talking about ;-)
– t3chb0t
Nov 22 at 15:49
@pieter, what is the space complexity of your solution? Can you please explain? I think it is O(n). Is it right?
– Emdad
Nov 25 at 9:39
@Emdad: it takes O(n) space, yes.
– Pieter Witvoet
Nov 25 at 14:14
@PieterWitvoet, thanks for your clarification. I am looking for O(1) space complexity for this problem. Can you please help me?
– Emdad
Nov 25 at 16:12
1
@Emdad: the last part of my post contains some notes about the O(1) solution that is shown on the website Gilad linked to. It's more complicated, slower and requires modifications to the input, so I don't see much practical use for it.
– Pieter Witvoet
Nov 25 at 19:32
add a comment |
1
.NET Framework 4.7.2
- that's why I've never seenToHashSet
before :-o I was wondering what you are talking about ;-)
– t3chb0t
Nov 22 at 15:49
@pieter, what is the space complexity of your solution? Can you please explain? I think it is O(n). Is it right?
– Emdad
Nov 25 at 9:39
@Emdad: it takes O(n) space, yes.
– Pieter Witvoet
Nov 25 at 14:14
@PieterWitvoet, thanks for your clarification. I am looking for O(1) space complexity for this problem. Can you please help me?
– Emdad
Nov 25 at 16:12
1
@Emdad: the last part of my post contains some notes about the O(1) solution that is shown on the website Gilad linked to. It's more complicated, slower and requires modifications to the input, so I don't see much practical use for it.
– Pieter Witvoet
Nov 25 at 19:32
1
1
.NET Framework 4.7.2
- that's why I've never seen ToHashSet
before :-o I was wondering what you are talking about ;-)– t3chb0t
Nov 22 at 15:49
.NET Framework 4.7.2
- that's why I've never seen ToHashSet
before :-o I was wondering what you are talking about ;-)– t3chb0t
Nov 22 at 15:49
@pieter, what is the space complexity of your solution? Can you please explain? I think it is O(n). Is it right?
– Emdad
Nov 25 at 9:39
@pieter, what is the space complexity of your solution? Can you please explain? I think it is O(n). Is it right?
– Emdad
Nov 25 at 9:39
@Emdad: it takes O(n) space, yes.
– Pieter Witvoet
Nov 25 at 14:14
@Emdad: it takes O(n) space, yes.
– Pieter Witvoet
Nov 25 at 14:14
@PieterWitvoet, thanks for your clarification. I am looking for O(1) space complexity for this problem. Can you please help me?
– Emdad
Nov 25 at 16:12
@PieterWitvoet, thanks for your clarification. I am looking for O(1) space complexity for this problem. Can you please help me?
– Emdad
Nov 25 at 16:12
1
1
@Emdad: the last part of my post contains some notes about the O(1) solution that is shown on the website Gilad linked to. It's more complicated, slower and requires modifications to the input, so I don't see much practical use for it.
– Pieter Witvoet
Nov 25 at 19:32
@Emdad: the last part of my post contains some notes about the O(1) solution that is shown on the website Gilad linked to. It's more complicated, slower and requires modifications to the input, so I don't see much practical use for it.
– Pieter Witvoet
Nov 25 at 19:32
add a comment |
Thanks for contributing an answer to Code Review Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
Use MathJax to format equations. MathJax reference.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f208218%2ffind-the-smallest-positive-number-missing-from-an-unsorted-array%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown