How to code a modulo operator in C C Obj-C that handles negative numbers

0 votes

As a mathematician, one of my pet peeves of C-derived languages is :

(-1) % 8 // comes out as -1, and not 7

fmodf(-1,8) // fails similarly

What is the most effective solution?

Templates and operator overloading are both possible in C++, but both are unfamiliar to me. 

Thank you for providing examples.

Jul 27, 2022 in C++ by Nicholas
• 7,760 points
936 views

No answer to this question. Be the first to respond.

Your answer

Your name to display (optional):
Privacy: Your email address will only be used for sending these notifications.
0 votes
First and foremost, I'd like to point out that you cannot rely on the assumption that (-1) % 8 == -1.

The sole certainty is that (x / y) * y + (x % y) == x.

However, whether or not the remainder is negative is determined by the implementation.

The binary / operator returns the quotient, whereas the binary percent operator returns the remainder of dividing the first expression by the second.

The behaviour is unknown if the second operand of / or percent is 0; otherwise, (a/b)*b + a % b equals a.

If both operands are nonnegative, the remainder is also nonnegative; otherwise, the remainder's sign is implementation-defined.

Here is a variant that handles both negative operands so that the result of subtracting the remainder from the divisor may be  subtracted from the dividend to get the real division's floor.

mod(-1,8) yields 7, but mod(13, -8) yields -3.
answered Aug 1, 2022 by Damon
• 4,960 points

edited Mar 5

Related Questions In C++

0 votes
1 answer

How to use new[ ] and delete[ ] operator in C++

int main(){ char *str; ...READ MORE

answered Jun 20, 2022 in C++ by Damon
• 4,960 points
1,091 views
0 votes
0 answers

How to find if a given key exists in a C++ std::map

I'm trying to check if a given ...READ MORE

Jul 14, 2022 in C++ by Nicholas
• 7,760 points
1,152 views
0 votes
0 answers

How to generate a random number in C++?

I'm attempting to develop a dice game, and I need random numbers to represent the sides of the die.  I can make a number between 1 and 6).  Using #include <cstdlib> #include <ctime> #include <iostream> using namespace ...READ MORE

Aug 11, 2022 in C++ by Nicholas
• 7,760 points
943 views
0 votes
1 answer

How to reverse a number in C++?

#include <iostream> using namespace std; int main() { int n; cin>>n; int ...READ MORE

answered Oct 28, 2024 in C++ by kavya
1,371 views
0 votes
1 answer

How to use std::sort to sort an array in C++

We receive std::begin and std::end in C++0x/11, which are overloaded for arrays: #include <algorithm> int main(){ int v[2000]; ...READ MORE

answered Jun 1, 2022 in C++ by Damon
• 4,960 points
1,874 views
0 votes
0 answers

How to traverse stack in C++?

Is traversing std::stack possible in C++? It is not possible to traverse using the following method.  Because there is no member end in std::stack. std::stack<int> foo; // .. for (__typeof(foo.begin()) it = foo.begin(); ...READ MORE

Jun 1, 2022 in C++ by Nicholas
• 7,760 points
2,915 views
0 votes
0 answers

Is hiding implementation detail Encapsulation or Abstraction?

I have seen some people defining abstraction ...READ MORE

May 6, 2022 in Java by narikkadan
• 86,360 points
4,078 views
0 votes
1 answer

Syntax of priority queue

We must first include the queue header file in order to establish a priority queue in C++. #include <queue> Once we import this file, we ...READ MORE

answered May 31, 2022 in C++ by Damon
• 4,960 points
1,122 views
0 votes
1 answer

Why would anyone use set instead of unordered_set?

Unordered sets must compensate for their O(1) ...READ MORE

answered Jun 1, 2022 in C++ by Damon
• 4,960 points
3,759 views
0 votes
1 answer

What is a smart pointer and when should I use one?

A smart pointer is similar to a ...READ MORE

answered Jun 2, 2022 in C++ by Damon
• 4,960 points
915 views
webinar REGISTER FOR FREE WEBINAR X
REGISTER NOW
webinar_success Thank you for registering Join Edureka Meetup community for 100+ Free Webinars each month JOIN MEETUP GROUP