89a872 No.2032                
The equation in pic related describes the behavior of cubes in any number of dimensions, with m being the total number of dimensions in a cube, and f(n m) describes "the number of n dimensional forms in a m dimensional cube."
Here's and example
>For a 2d cube (flat square), m=2. A line segment is n=1. Therefor f(n m)=f(1 2)=4,  since a square has four sides
Let's try again and count the edges in a 3d cube
>For a 3d cube, m=3. A line segment is n=1. f(n m)=f(1 3)=12, since there are 12 edges to a cube
Now let's change n=1 (a line) to n=2 (a flat square)
>Fore a 3d cube, m=3. n=2 is a flat square.  Therefor f(n m)=f(2 3)=6, since a cube has 6 sides
Now how would I go about writing this in C++? I've been fucking around with it all afternoon and nothing I do seems to work
        ____________________________        
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2045
    >>2032>I've been fucking around with it all afternoon and nothing I do seems to workWhat do you have so far? What, specifically, didn't work?
                 Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2051
    >>2045Before I post it how do I use code tags?
(Yes, I'm a newfag. That much should be obvious judging by the fact that I can't do factorials)
                 Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2053
    >a 2d cube
W-what.
                Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2055
    The nieve way would be to use recursion, and that would work for some certain size of numbers, but eventually you'll run out of memory and crash. A better solution would be to use memoization so you don't have to build a stack of function calls every time you want to calculate the next factorial.
                Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2066
    code tags are just [code]…[/code]
function factorial(int n) {
  int result = 0;
  for(int i = 0; i < n; i++) {
    result *= i;
  }
  return result;
}
not sure if it works but it should.
now you just call that with the right values, you should really be able to figure out how.
iirc we used your formula at school for some stochastics calculations but i never heard a geometrical explanation for it or that it has use cases other than calculating some probabilities.
can you give more background info about that formula? too lazy to google it…
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2068
    >>2066 oops, i fucked up the function. am not quite awake yet and thought factorials are 1+2+3+4.. then i realized it's got to do with multiplication and changed + to *
anyway, let's try again:
function factorial(int n) {
  int result = 1;
  for(int i = 1; i < n; i++) {
    result *= i;
  }
  return result;
}factorial(0) == 1
factorial(1) == 1
factorial(2) == 2
factorial(3) == 6
only works for positive numbers so filter out negatives if your prof requires that.
                 Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2074
    >>2051>Before I post it how do I use code tags?See: 
>>>/hdi8/ (the official™how-to board)
For longer code though, use a pastebin.
                 Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2081
    >>2053A line, square (2d "cube"), true cube, and tesseract are all increasing complex iterations of one another
                 Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2096
    >>2081That I know, but I have never seen a square get referred to as 2D cube. It seems a bit stupid considering a cube is implicitly 3D and there is already a word for that.
It is more or less like saying "a third person FPS".
                 Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2188
    >>2068
That's fine. It's not for school, it's for fun/autism
I lost my first bit of source code, but I have some notes of it written own in one of my [paper] notebooks.
I'll post a copy of it when I'm done retyping it
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2189
    >>2096
True. Objects with greater than 3 dimensions are still collectively called "(hyper)cubes" for ease of discussion, even if they do have specific names like "tesseract"
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2302
    #include <iostream>
using namespace std;
int n;
int m;
int a;
int b;
int c;
int d;
int e;
int f;
//functions//
int factorial1(int n) {
  int result = 1;
  for(int a = 1; a < n; a++) {
    result *= a;
  }
  return result;
}
int factorial2(int m) {
  int result = 1;
  for(int b = 1; b < m; b++) {
    result *= b;
  }
  return result;
}
int factorial3(int c) {
  int result = 1;
  for(int d = 1; d < c; d++) {
    result *= d;
  }
  return result;
}
int subtraction (int n, int m)
{
	int c;
	c = n - m;
	return c;
}
int multiplication (int b, int d)
{
	int e;	
	e = b * d;
	return e;
}
int division (int a, int e)
{
	int f;
	f = a / e;
	return f;
}
int main ()
{
cout << "Please enter the number of dimensions of the form in question.\nWe'll call this the n-value.\n";
cin >> n;
cout << "Now we can find the number of m-dimensional forms in an n-dimensional object.\nPlease define the m-value. Note that it should be equal to or less than the value of m.\n";
cin >> m;
a = factorial1 (n);
b = factorial2 (m);
c = subtraction  (n, m);
d = factorial3 (c);
e = multiplication (b, d);
f = division (a, e);
cout << f;
system ("PAUSE") ;
return 0;
}
Here's what I have so far. IDK why it doesn't work. For some reason the functions don't seem to be working, so there's no "f" to "cout <<"
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2303
                    Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2306
    >not using permutations to calculate combinations
uint permu(uint x, uint y) {
    uint k = x-y;
    uint j = x;
    while(–j>k) x *= j;
    return x;
}
uint comb(uint x, uint y){
    return perm(x,y)/fact(y);
}
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2312
    >>2303
Eh he's just learning
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2320
    >>2302
There are a few problems here, namely:
1.) There is no reason to declare all of those variables at the beginning of the file
2.) There is no reason to declare all of those variables in the first place
3.) You should only have one factorial function
4.) The "subtraction", "multiplication", and "division" functions really shouldn't exist
5.) Using the system() function is almost always wrong - in this case, use cin.get() (or better yet, don't lock up the terminal at all)
This:
>https://clbin.com/ROf0S
Will reproduce the table in >>2189
I rearranged the original equation slightly, though.
Bonus points and cake if you can guess why. It wasn't to make it faster.
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2322
    Using recursion:
int factorial(int a) {
    if (a == 1) {
        return 1;
        }
    int b = factorial(a-1);
    return a*b;
}
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2323
    >>2320
Thanks, I'll check it out when I get home. I've just been learning to program over the past few weeks so I'd say 97% of it is stuff  I don't know
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2324
    Oh, and one other question: why should I use std::cout instead of using namespace std?
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2329
    >>2324
>Oh, and one other question: why should I use std::cout instead of using namespace std?
A "namespace" groups things together so that two objects sharing the same name don't conflict with eachother.
For example, if you created your own "cout", like this:
#include <iostream>
#include <fstream>
int main(void)
{
    // Please don't actually name your variable "cout"
    std::ofstream cout("some_file.txt");
    cout << "This gets saved to a file" << std::endl;
    std::cout << "This gets printed on the screen" << std::endl;
    return 0;
}
This works fine, since "cout" is in a different namespace than "std::cout".
If you were to use "using namespace std" though (and removed all the "std::" parts),
then "This gets printed on the screen" would also be written to the file, since the local
"cout" overloads the global one.
Of course, for simple programs, it doesn't actually matter - the "rule" is for complex programs with lots of namespaces.
tl;dr - Be specific so that the computer and other programmers know what the hell you're trying to do
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2353
    >>2322
recursion is bad and has no place in real life applications. write iteratively.
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2363
    >>2353
>has no place in real life applications
Yeah, totally. Who needs those shitty "parsers" anyway?
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2433
    >>2363
Shift-reduce parsers are typically superior to recursive descent parsers. RD is just easier to implement by hand.
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.2435
                    Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.4057
    >>2032
What the fuck? You calculate n choose k by using pascal's triangle + memoization. Does anyone on /prog/ know how to program?
#include <stdio.h>
#include <stdint.h>
/* col > row is undefined */
uint64_t tb[5000][5000];
uint64_t pascal(const uint64_t row, const uint64_t col) {
	if(!col || col == row) return tb[row][col] = 1;
	if(tb[row][col]) return tb[row][col];
	return tb[row][col] = pascal(row - 1, col - 1) + pascal(row - 1, col);
}
int main() {
	uint64_t n, k;
	while(scanf("%lld%lld", &n, &k) == 2) {
		printf("%lld choose %lld = %lld\n", n, k, pascal(n, k));
	}
	return 0;
}
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.        
                 89a872 No.4075
    >>4057
>clogging up the cache with a 5000x5000 2d array of 64 bits integers
        Disclaimer: this post and the subject matter and contents thereof - text, media, or otherwise - do not necessarily reflect the views of the 8kun administration.