Cı, 775 771 karakter
char*e[]={"h","he","li","be","b","c","n","o","f","ne","na","mg","al","si","p","s","cl","ar","k","ca","sc","ti","v","cr","mn","fe","co","ni","cu","zn","ga","ge","as","se","br","kr","rb","sr","y","zr","nb","mo","tc","ru","rh","pd","ag","cd","in","sn","sb","te","i","xe","cs","ba","la","ce","pr","nd","pm","sm","eu","gd","tb","dy","ho","er","tm","yb","lu","hf","ta","w","re","os","ir","pt","au","hg","tl","pb","bi","po","at","rn","fr","ra","ac","th","pa","u","np","pu","am","cm","bk","cf","es","fm","md","no","lr","rf","db","sg","bh","hs","mt","ds","rg","cn","uut","fl","uup","lv","uus","uu",0};
b[99],n;
c(w,o,l)char*w,*o,**l;{
return!*w||!strncmp(*l,w,n=strlen(*l))&&c(w+n,o+sprintf(o,",%d",l-e+1),e)||*++l&&c(w,o,l);
}
main(){
while(gets(b))c(b,b+9,e)&&printf("%s%s\n",b,b+9);
}
Girdi : Satır başına sözcük, küçük harf olmalıdır. usr/share/dict/wordsiyi.
Çıktı : Kelime ve sayılar, örneğin:acceptances,89,58,15,73,7,6,99
Mantık : öğeden başlayarak
c(w,o,l)kelimeyi kontrol eder .
İki yönlü özyineleme kullanılır - ilk öğe, öğe listesinin başıyla eşleşiyorsa, kalan öğeyi tam öğe listesine göre kontrol edin . Bu eşleşme başarısız olursa, listenin kuyruğundaki kelimeyi kontrol edin.
Arabellek , başarılı yol boyunca eleman numaralarını biriktirir. Bir eşleşmeden sonra, numaraların listesini içerir ve yazdırılır.wl
w
o
Sorunlar :
Liste verimli bir şekilde kodlanmadı - çok fazla "ve ,". Ama bu şekilde kullanımı kolaydır. Eminim, kodda çok fazla maliyet olmadan çok daha geliştirilebilir.