%I #11 Aug 31 2017 21:33:49
%S 3,5,7,9,6,11,15,17,12,21,13,19,14,23,31,33,24,20,25,37,22,26,27,35,
%T 28,43,29,39,30,47,63,65,48,40,49,73,38,41,51,69,44,85,45,50,46,53,55,
%U 67,56,52,57,75,54,58,59,71,60,87,61,79,62,95,127,129,96,80,97,72,70,81,99
%N a(n) = the smallest integer > n such that both n and a(n), when represented in binary, contain the same types of runs of 0's, the runs being in any order.
%C Clarification of definition: Think of binary n and a(n) each as a string of 0's and 1's. Consider the "runs" of 0's in binary n and a(n), where each run is made up completely of 0's, and is bounded on both sides either by 1's or by the edge of the string. Now consider the lengths of each bounded run of 0's (the number of 0's in each run). Then a(n) is the smallest integer greater than n whose set of runlengths is a permutation of the set of runlengths for n. (See example.)
%H Michael De Vlieger, <a href="/A161821/b161821.txt">Table of n, a(n) for n = 1..10000</a>
%e 84 in binary is 1010100. There are three runs of 0's, two runs of one 0 each and one run of two 0's. So we are looking for the smallest integer > 84 with two runs of one 0 each and one run of two 0's (and no other runs of 0's). For example, 88 in binary is 1011000, which contains the runs, except that it is required that each run be bounded by 1's or the edge of the binary string. The next number that fits the requirements completely is 149 = 10010101 in binary. So a(84) = 149.
%p rtype := proc(n) local rt, bdgs,pr,i,rl ; rt := [seq(0,i=1..40)] ; bdgs := convert(n,base,2) ; pr := 1 ; for i from 1 to nops(bdgs) do if op(i,bdgs) = 0 then if pr = 1 then rl := 0 ; fi; rl := rl+1 ; else if pr = 0 then rt := subsop(rl=op(rl,rt)+1,rt) ; fi; fi; pr := op(i,bdgs) ; if i = nops(bdgs) and pr = 0 then rt := subsop(rl=op(rl,rt)+1,rt) ; fi; od: rt ; end: A161821 := proc(n) local rtn,a; rtn := rtype(n) ; for a from n+1 do if rtype(a) = rtn then RETURN(a) ; fi; od: end: seq(A161821(n),n=1..100) ; # _R. J. Mathar_, Jul 20 2009
%t f[n_] := Sort@ Map[Length, Select[Split@ IntegerDigits[n, 2], First@ # == 0 &]]; Table[Block[{k = n + 1}, While[f@ k != f@ n, k++]; k], {n, 71}] (* _Michael De Vlieger_, Aug 31 2017 *)
%Y Cf. A161819, A161820, A161822.
%K base,nonn
%O 1,1
%A _Leroy Quet_, Jun 20 2009
%E More terms from _R. J. Mathar_, Jul 20 2009
