This is part of a series where I explore some of the videos of Numberphile, see also the other ones:
Today we are gonna look at the graphs from https://www.youtube.com/watch?v=o8c4uYnnNnc
The first can be really easily made:
n = 3^5 - 1;
nums = FromDigits[IntegerDigits[#, 3] /. 2 -> -1, 3] & /@ Range[n];
ListPlot[nums]
data:image/s3,"s3://crabby-images/c507f/c507f6729739c6d4a03a5e0686e1c71bd7047b26" alt="enter image description here"
The second can also be easily made using the following code:
n = 1000;
nums = # - (Times @@ DeleteCases[IntegerDigits[#], 0]) & /@ Range[n];
ListPlot[nums]
giving:
data:image/s3,"s3://crabby-images/0a494/0a4946d1a38d33bf46e5c607090e09300ebcb565" alt="enter image description here"
The last sequence is harder to program, especially if one wants a fast solutionÂ… Here is the code:
x = ConstantArray[1, 10^5];
x[[;; 2]] = {1, 1};
Dynamic[i]
AbsoluteTiming@Do[
max = Floor[(i - 1)/2];
invalid = 2 x[[i - max ;; i - 1]] - x[[i - 2 max ;; i - 2 ;; 2]];
invalid = Pick[invalid, 1 - UnitStep[-invalid], 1]; (*
remove nonpositive *)
invalid = Sort[DeleteDuplicates[invalid]];
new = -1;
If[Last[invalid] == Length[invalid],
new = Length[invalid] + 1;
,
Do[
If[invalid[[k]] =!= k,
new = k;
Break[];
]
,
{k, 1, Length[invalid]}
];
If[new == -1, new = Last[invalid] + 1];
];
x[[i]] = new;
,
{i, 3, Length[x]}
]
ListPlot[x]
giving:
data:image/s3,"s3://crabby-images/937b1/937b14ce740f9e7b7e3b0e0d25d134b511de9535" alt="enter image description here"
Hope you enjoyed these codes, perhaps you can modify them and make them more intricate/faster/better!