<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Find max continuity 1 and 0 in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366569#M87221</link>
    <description>&lt;P&gt;This should do it:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
set test;
array nums{*} m1-m12;
count = 0;
continuity = 0;
i = 1;
do until(i &amp;gt; dim(nums));
  if nums{i} = 1
  then count + 1;
  else do;
    continuity = max(continuity,count);
    count = 0;
  end;
  i + 1;
end;
continuity = max(continuity,count);
drop i count;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Tue, 13 Jun 2017 13:59:54 GMT</pubDate>
    <dc:creator>Kurt_Bremser</dc:creator>
    <dc:date>2017-06-13T13:59:54Z</dc:date>
    <item>
      <title>Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366544#M87216</link>
      <description>&lt;P&gt;Hello everybody,&lt;/P&gt;&lt;P&gt;I have this task that I can't find a easy solution and I know you will.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;IMG src="https://communities.sas.com/t5/image/serverpage/image-id/9350i7E245D1DB59984A4/image-size/original?v=1.0&amp;amp;px=-1" border="0" alt="continuity_example.PNG" title="continuity_example.PNG" /&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I need to calculate the max amount of continuos 1, like in the image below. (the var continuity is the desire one)&lt;/P&gt;&lt;P&gt;Thanks.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 13 Jun 2017 13:20:31 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366544#M87216</guid>
      <dc:creator>Feragon42</dc:creator>
      <dc:date>2017-06-13T13:20:31Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366555#M87218</link>
      <description>&lt;P&gt;Use an array; while scanning through the array, count a current counter for 1's, and when getting a 0 or reaching the end of the array, do a max() to set the final continuous variable (and reset the current counter).&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;If you want a code example, provide your data in a data step for copy/pasting.&lt;/P&gt;</description>
      <pubDate>Tue, 13 Jun 2017 13:34:54 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366555#M87218</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2017-06-13T13:34:54Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366561#M87219</link>
      <description>&lt;P&gt;Thanks for your answer and your time.&lt;/P&gt;&lt;P&gt;There is an example (I need to get use to bring one haha sorry)&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data test;&lt;BR /&gt;input id m1 m2 m3 m4 m5 m6 m7 m8 m9 m10 m11 m12;&lt;BR /&gt;datalines;&lt;BR /&gt;3424 0 1 0 0 0 0 1 1 1 0 1 1&lt;BR /&gt;5432 1 1 1 1 1 1 0 0 1 0 1 0&lt;BR /&gt;3930 0 1 0 1 1 1 1 0 0 1 1 1&lt;BR /&gt;6053 0 1 0 1 0 0 0 0 0 0 0 0&lt;BR /&gt;9493 1 1 1 1 1 0 0 0 0 0 1 1&lt;BR /&gt;4984 1 1 0 0 0 1 1 0 0 0 1 1&lt;BR /&gt;2039 0 1 1 1 1 0 0 0 0 1 0 0&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks a lot.&lt;/P&gt;</description>
      <pubDate>Tue, 13 Jun 2017 13:45:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366561#M87219</guid>
      <dc:creator>Feragon42</dc:creator>
      <dc:date>2017-06-13T13:45:17Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366569#M87221</link>
      <description>&lt;P&gt;This should do it:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
set test;
array nums{*} m1-m12;
count = 0;
continuity = 0;
i = 1;
do until(i &amp;gt; dim(nums));
  if nums{i} = 1
  then count + 1;
  else do;
    continuity = max(continuity,count);
    count = 0;
  end;
  i + 1;
end;
continuity = max(continuity,count);
drop i count;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 13 Jun 2017 13:59:54 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366569#M87221</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2017-06-13T13:59:54Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366575#M87222</link>
      <description>&lt;P&gt;Thanks! This works!&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 13 Jun 2017 14:04:30 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366575#M87222</guid>
      <dc:creator>Feragon42</dc:creator>
      <dc:date>2017-06-13T14:04:30Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366581#M87223</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data test;
input id m1 m2 m3 m4 m5 m6 m7 m8 m9 m10 m11 m12;
datalines;
3424 0 1 0 0 0 0 1 1 1 0 1 1
5432 1 1 1 1 1 1 0 0 1 0 1 0
3930 0 1 0 1 1 1 1 0 0 1 1 1
6053 0 1 0 1 0 0 0 0 0 0 0 0
9493 1 1 1 1 1 0 0 0 0 0 1 1
4984 1 1 0 0 0 1 1 0 0 0 1 1
2039 0 1 1 1 1 0 0 0 0 1 0 0
2039 0 0 0 0 0 0 0 0 0 0 0 0
;


data temp;
set test;
 array x{*} m:;
continuity=0;n=0;
 do i=1 to dim(x);
  if x{i}=1 then do;
   n=1;
   do j=i+1 to dim(x);
    if x{j}=1 then n+1;
     else leave;
   end;
  end;
  continuity=max(continuity,n);
 end;
drop n i j;
run;

proc print noobs;run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 13 Jun 2017 14:15:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366581#M87223</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2017-06-13T14:15:04Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366583#M87224</link>
      <description>&lt;P&gt;another logic a bit lengthy&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input id m1 m2 m3 m4 m5 m6 m7 m8 m9 m10 m11 m12;
datalines;
3424 0 1 0 0 0 0 1 1 1 0 1 1
5432 1 1 1 1 1 1 0 0 1 0 1 0
3930 0 1 0 1 1 1 1 0 0 1 1 1
6053 0 1 0 1 0 0 0 0 0 0 0 0
9493 1 1 1 1 1 0 0 0 0 0 1 1
4984 1 1 0 0 0 1 1 0 0 0 1 1
2039 0 1 1 1 1 0 0 0 0 1 0 0
;

data want;
set have;
array c(*) m1-m12;
do i = 1 to dim(c);
m=c(i);
output;
end;
run;

data want2;
set want;
by id notsorted;
retain mc;
if first.id then mc=.;
if m eq 0 then mc=m;
else mc+m;
drop i m ;
run;

proc sql;
create table want3 as select distinct *  from want2 group by id having mc=max(mc);
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 13 Jun 2017 14:14:08 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366583#M87224</guid>
      <dc:creator>Jagadishkatam</dc:creator>
      <dc:date>2017-06-13T14:14:08Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366697#M87252</link>
      <description>&lt;P&gt;Can't skip this party &lt;img id="smileylol" class="emoticon emoticon-smileylol" src="https://communities.sas.com/i/smilies/16x16_smiley-lol.png" alt="Smiley LOL" title="Smiley LOL" /&gt;&lt;/P&gt;
&lt;LI-SPOILER&gt;&amp;nbsp;&lt;/LI-SPOILER&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;How about this non-orthodox solution:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;options missing='';

data test;
input id m1 m2 m3 m4 m5 m6 m7 m8 m9 m10 m11 m12;
datalines;
3424 0 1 0 0 0 0 1 1 1 0 1 1
5432 1 1 1 1 1 1 0 0 1 0 1 0
3930 0 1 0 1 1 1 1 0 0 1 1 1
6053 0 1 0 1 0 0 0 0 0 0 0 0
9493 1 1 1 1 1 0 0 0 0 0 1 1
4984 1 1 0 0 0 1 1 0 0 0 1 1
2039 0 1 1 1 1 0 0 0 0 1 0 0
2039 0 0 0 0 0 0 0 0 0 0 0 0
;

data want;
set test;
length _3 $12 _4 $12 _1 $12;
_1=cats(of m:);
do _i=1 by 1 until (missing(_3));
_3=scan(_1,_i,'0');
_4=max(_4,_3);
end;
continuity=lengthn(strip(_4));
drop _:;
run;
&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 13 Jun 2017 17:25:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366697#M87252</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2017-06-13T17:25:09Z</dc:date>
    </item>
    <item>
      <title>Re: Find max continuity 1 and 0</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366948#M87327</link>
      <description>&lt;P&gt;HaiKuo's code remind me to use CALL SCAN.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data test;
input id m1 m2 m3 m4 m5 m6 m7 m8 m9 m10 m11 m12;
datalines;
3424 0 1 0 0 0 0 1 1 1 0 1 1
5432 1 1 1 1 1 1 0 0 1 0 1 0
3930 0 1 0 1 1 1 1 0 0 1 1 1
6053 0 1 0 1 0 0 0 0 0 0 0 0
9493 1 1 1 1 1 0 0 0 0 0 1 1
4984 1 1 0 0 0 1 1 0 0 0 1 1
2039 0 1 1 1 1 0 0 0 0 1 0 0
2039 0 0 0 0 0 0 0 0 0 0 0 0
;

data want;
set test;
temp=cats(of m:);
continutity=0;
do i=1 to countw(strip(temp),'0');
 call scan(strip(temp),i,p,l,'0');
 continutity=max(continutity,l);
end;
drop i p l temp;
run;
proc print ;run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Wed, 14 Jun 2017 13:36:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-max-continuity-1-and-0/m-p/366948#M87327</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2017-06-14T13:36:04Z</dc:date>
    </item>
  </channel>
</rss>

