Is there a way to avoid BigInteger/BigDecimal?
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}
I need to compute something like this (pseudocode):
// a, b, x, y are long, x,y <= 10^12
long i = (a - n)/(x*y)
and
long j = (b - n)/(x*y) - ceiling
Sometimes x*y doesn't fit in long. I would like to avoid BigDecimal/BigInteger usage as it is too costly and not needed anywhere else. Is there a smart math solution e.g. with two longs or smth like that?
Thank you!
UPDATE: Sorry, guys, one more constraint: I also have a variable computed as following (maybe it can be rewritten as well):
sum += x*y
I need to recalculate it to compare with another variable to stop the cycle.
java algorithm optimization bigdecimal
add a comment |
I need to compute something like this (pseudocode):
// a, b, x, y are long, x,y <= 10^12
long i = (a - n)/(x*y)
and
long j = (b - n)/(x*y) - ceiling
Sometimes x*y doesn't fit in long. I would like to avoid BigDecimal/BigInteger usage as it is too costly and not needed anywhere else. Is there a smart math solution e.g. with two longs or smth like that?
Thank you!
UPDATE: Sorry, guys, one more constraint: I also have a variable computed as following (maybe it can be rewritten as well):
sum += x*y
I need to recalculate it to compare with another variable to stop the cycle.
java algorithm optimization bigdecimal
Comments are not for extended discussion; this conversation has been moved to chat.
– Samuel Liew♦
Jan 3 at 23:13
add a comment |
I need to compute something like this (pseudocode):
// a, b, x, y are long, x,y <= 10^12
long i = (a - n)/(x*y)
and
long j = (b - n)/(x*y) - ceiling
Sometimes x*y doesn't fit in long. I would like to avoid BigDecimal/BigInteger usage as it is too costly and not needed anywhere else. Is there a smart math solution e.g. with two longs or smth like that?
Thank you!
UPDATE: Sorry, guys, one more constraint: I also have a variable computed as following (maybe it can be rewritten as well):
sum += x*y
I need to recalculate it to compare with another variable to stop the cycle.
java algorithm optimization bigdecimal
I need to compute something like this (pseudocode):
// a, b, x, y are long, x,y <= 10^12
long i = (a - n)/(x*y)
and
long j = (b - n)/(x*y) - ceiling
Sometimes x*y doesn't fit in long. I would like to avoid BigDecimal/BigInteger usage as it is too costly and not needed anywhere else. Is there a smart math solution e.g. with two longs or smth like that?
Thank you!
UPDATE: Sorry, guys, one more constraint: I also have a variable computed as following (maybe it can be rewritten as well):
sum += x*y
I need to recalculate it to compare with another variable to stop the cycle.
java algorithm optimization bigdecimal
java algorithm optimization bigdecimal
edited Jan 3 at 8:57
Dmitry Senkovich
asked Jan 3 at 8:29


Dmitry SenkovichDmitry Senkovich
2,14111541
2,14111541
Comments are not for extended discussion; this conversation has been moved to chat.
– Samuel Liew♦
Jan 3 at 23:13
add a comment |
Comments are not for extended discussion; this conversation has been moved to chat.
– Samuel Liew♦
Jan 3 at 23:13
Comments are not for extended discussion; this conversation has been moved to chat.
– Samuel Liew♦
Jan 3 at 23:13
Comments are not for extended discussion; this conversation has been moved to chat.
– Samuel Liew♦
Jan 3 at 23:13
add a comment |
2 Answers
2
active
oldest
votes
You could divide two times
y = a / (b * c)
y1 = a / b
y = y1 / c
It's hard to understand how you use this sum
exactly and how the compared value is calculated but would it be possible to store the result of the comparison instead to avoid large values such as if result
> 0 then sum
is larger, if result < 0 then other value is larger,...
seems to be reasonable but I also need to store the current sum of suchm*w
, sorry, I've updated the question
– Dmitry Senkovich
Jan 3 at 8:42
add a comment |
I've noticed that the value I'm comparing the sum
with is long. So I've solved the problem in the following way:
- I'm calculating
i
like this: (long) (((a - n) / (double) x) / y)) - Here goes
j
: (long) Math.ceil((b - n) / (double) x*y)
The case above overflows of course. But I prevent overflowing doing the following try-catch before:
try {
xy = Math.multiplyExact(x, y);
...
} catch (ArithmeticException ex) {
// some handling
break;
}
This trick made by code work faster enough.
Hope it helps someone!
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
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%2fstackoverflow.com%2fquestions%2f54018706%2fis-there-a-way-to-avoid-biginteger-bigdecimal%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
You could divide two times
y = a / (b * c)
y1 = a / b
y = y1 / c
It's hard to understand how you use this sum
exactly and how the compared value is calculated but would it be possible to store the result of the comparison instead to avoid large values such as if result
> 0 then sum
is larger, if result < 0 then other value is larger,...
seems to be reasonable but I also need to store the current sum of suchm*w
, sorry, I've updated the question
– Dmitry Senkovich
Jan 3 at 8:42
add a comment |
You could divide two times
y = a / (b * c)
y1 = a / b
y = y1 / c
It's hard to understand how you use this sum
exactly and how the compared value is calculated but would it be possible to store the result of the comparison instead to avoid large values such as if result
> 0 then sum
is larger, if result < 0 then other value is larger,...
seems to be reasonable but I also need to store the current sum of suchm*w
, sorry, I've updated the question
– Dmitry Senkovich
Jan 3 at 8:42
add a comment |
You could divide two times
y = a / (b * c)
y1 = a / b
y = y1 / c
It's hard to understand how you use this sum
exactly and how the compared value is calculated but would it be possible to store the result of the comparison instead to avoid large values such as if result
> 0 then sum
is larger, if result < 0 then other value is larger,...
You could divide two times
y = a / (b * c)
y1 = a / b
y = y1 / c
It's hard to understand how you use this sum
exactly and how the compared value is calculated but would it be possible to store the result of the comparison instead to avoid large values such as if result
> 0 then sum
is larger, if result < 0 then other value is larger,...
edited Jan 3 at 12:42
answered Jan 3 at 8:34
Joakim DanielsonJoakim Danielson
10.6k3725
10.6k3725
seems to be reasonable but I also need to store the current sum of suchm*w
, sorry, I've updated the question
– Dmitry Senkovich
Jan 3 at 8:42
add a comment |
seems to be reasonable but I also need to store the current sum of suchm*w
, sorry, I've updated the question
– Dmitry Senkovich
Jan 3 at 8:42
seems to be reasonable but I also need to store the current sum of such
m*w
, sorry, I've updated the question– Dmitry Senkovich
Jan 3 at 8:42
seems to be reasonable but I also need to store the current sum of such
m*w
, sorry, I've updated the question– Dmitry Senkovich
Jan 3 at 8:42
add a comment |
I've noticed that the value I'm comparing the sum
with is long. So I've solved the problem in the following way:
- I'm calculating
i
like this: (long) (((a - n) / (double) x) / y)) - Here goes
j
: (long) Math.ceil((b - n) / (double) x*y)
The case above overflows of course. But I prevent overflowing doing the following try-catch before:
try {
xy = Math.multiplyExact(x, y);
...
} catch (ArithmeticException ex) {
// some handling
break;
}
This trick made by code work faster enough.
Hope it helps someone!
add a comment |
I've noticed that the value I'm comparing the sum
with is long. So I've solved the problem in the following way:
- I'm calculating
i
like this: (long) (((a - n) / (double) x) / y)) - Here goes
j
: (long) Math.ceil((b - n) / (double) x*y)
The case above overflows of course. But I prevent overflowing doing the following try-catch before:
try {
xy = Math.multiplyExact(x, y);
...
} catch (ArithmeticException ex) {
// some handling
break;
}
This trick made by code work faster enough.
Hope it helps someone!
add a comment |
I've noticed that the value I'm comparing the sum
with is long. So I've solved the problem in the following way:
- I'm calculating
i
like this: (long) (((a - n) / (double) x) / y)) - Here goes
j
: (long) Math.ceil((b - n) / (double) x*y)
The case above overflows of course. But I prevent overflowing doing the following try-catch before:
try {
xy = Math.multiplyExact(x, y);
...
} catch (ArithmeticException ex) {
// some handling
break;
}
This trick made by code work faster enough.
Hope it helps someone!
I've noticed that the value I'm comparing the sum
with is long. So I've solved the problem in the following way:
- I'm calculating
i
like this: (long) (((a - n) / (double) x) / y)) - Here goes
j
: (long) Math.ceil((b - n) / (double) x*y)
The case above overflows of course. But I prevent overflowing doing the following try-catch before:
try {
xy = Math.multiplyExact(x, y);
...
} catch (ArithmeticException ex) {
// some handling
break;
}
This trick made by code work faster enough.
Hope it helps someone!
answered Jan 4 at 9:30


Dmitry SenkovichDmitry Senkovich
2,14111541
2,14111541
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- 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%2fstackoverflow.com%2fquestions%2f54018706%2fis-there-a-way-to-avoid-biginteger-bigdecimal%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
Comments are not for extended discussion; this conversation has been moved to chat.
– Samuel Liew♦
Jan 3 at 23:13