70 lines
1.3 KiB
Arduino
Raw Normal View History

2021-01-29 12:31:58 +01:00
//
// FILE: perm1.ino
// AUTHOR: Rob Tillaart
// DATE: 2010-11-23
// PUPROSE: demo permutations
//
2021-12-28 15:37:03 +01:00
//
2021-01-29 12:31:58 +01:00
// WARNING TAKES LONG
2021-12-28 15:37:03 +01:00
// ========================================================================
// ESP32 @ 240 MHz string length 8 ==> ~8100 milliseconds => printing!!
// UNO no printing string length 8 ==> ~431 milliseconds
// UNO no printing string length 10 ==> ~38763 milliseconds
2021-01-29 12:31:58 +01:00
char permstring[12] = "0123456789"; // can be made slightly longer
uint32_t start, stop;
2021-12-28 15:37:03 +01:00
2021-01-29 12:31:58 +01:00
void permutate(char * array, uint8_t n)
{
if (n == 0) // end reached print the string
{
// Serial.println(array); // process permutation
return;
}
for (int i = 0; i < n; i++)
{
// swap
char t = array[i];
array[i] = array[n - 1];
array[n - 1] = t;
// permutate substrings
permutate(array, n - 1);
// swap back
t = array[i];
array[i] = array[n - 1];
array[n - 1] = t;
}
}
2021-12-28 15:37:03 +01:00
2021-01-29 12:31:58 +01:00
void setup()
{
Serial.begin(500000);
Serial.println("Will take some time..");
Serial.print("perm1 strlen: ");
Serial.println(strlen(permstring));
start = millis();
permutate(permstring, strlen(permstring));
stop = millis();
Serial.print("TIME: ");
Serial.println(stop - start);
}
2021-12-28 15:37:03 +01:00
2021-01-29 12:31:58 +01:00
void loop()
{
}
2021-12-28 15:37:03 +01:00
2021-01-29 12:31:58 +01:00
// -- END OF FILE --
2021-12-28 15:37:03 +01:00