我需要Shannon-Fano算法在C# 有沒有任何機構可以幫助我?我需要香農Fano算法在C#
2
A
回答
0
這是我在http://cppgm.blogspot.com/2008/01/shano-fano-code.html找到的一個。
我認爲它不應該花太多努力將其移植到C#。
#include< stdio.h>
#include< conio.h>
#include< string.h>
struct node
{
char sym[10];
float pro;
int arr[20];
int top;
}s[20];
typedef struct node node;
void prints(int l,int h,node s[])
{
int i;
for(i=l;i< =h;i++)
{
printf("\n%s\t%f",s[i].sym,s[i].pro);
}
}
void shannon(int l,int h,node s[])
{
float pack1=0,pack2=0,diff1=0,diff2=0;
int i,d,k,j;
if((l+1)==h || l==h || l>h)
{
if(l==h || l>h)
return;
s[h].arr[++(s[h].top)]=0;
s[l].arr[++(s[l].top)]=1;
return;
}
else
{
for(i=l;i< =h-1;i++)
pack1=pack1+s[i].pro;
pack2=pack2+s[h].pro;
diff1=pack1-pack2;
if(diff1< 0)
diff1=diff1*-1;
j=2;
while(j!=h-l+1)
{
k=h-j;
pack1=pack2=0;
for(i=l;i< =k;i++)
pack1=pack1+s[i].pro;
for(i=h;i>k;i--)
pack2=pack2+s[i].pro;
diff2=pack1-pack2;
if(diff2< 0)
diff2=diff2*-1;
if(diff2>=diff1)
break;
diff1=diff2;
j++;
}
k++;
for(i=l;i< =k;i++)
s[i].arr[++(s[i].top)]=1;
for(i=k+1;i< =h;i++)
s[i].arr[++(s[i].top)]=0;
shannon(l,k,s);
shannon(k+1,h,s);
}
}
void main()
{
int n,i,j;
float x,total=0;
char ch[10];
node temp;
clrscr();
printf("Enter How Many Symbols Do You Want To Enter\t: ");
scanf("%d",&n);
for(i=0;i< n;i++)
{
printf("Enter symbol %d ---> ",i+1);
scanf("%s",ch);
strcpy(s[i].sym,ch);
}
for(i=0;i< n;i++)
{
printf("\n\tEnter probability for %s ---> ",s[i].sym);
scanf("%f",&x);
s[i].pro=x;
total=total+s[i].pro;
if(total>1)
{
printf("\t\tThis probability is not possible.Enter new probability");
total=total-s[i].pro;
i--;
}
}
s[i].pro=1-total;
for(j=1;j< =n-1;j++)
{
for(i=0;i< n-1;i++)
{
if((s[i].pro)>(s[i+1].pro))
{
temp.pro=s[i].pro;
strcpy(temp.sym,s[i].sym);
s[i].pro=s[i+1].pro;
strcpy(s[i].sym,s[i+1].sym);
s[i+1].pro=temp.pro;
strcpy(s[i+1].sym,temp.sym);
}
}
}
for(i=0;i< n;i++)
s[i].top=-1;
shannon(0,n-1,s);
printf("---------------------------------------------------------------");
printf("\n\n\n\tSymbol\tProbability\tCode");
for(i=n-1;i>=0;i--)
{
printf("\n\t%s\t%f\t",s[i].sym,s[i].pro);
for(j=0;j< =s[i].top;j++)
printf("%d",s[i].arr[j]);
}
printf("\n---------------------------------------------------------------");
getch();
}
相關問題
- 1. 香農的Fano算法
- 2. 香農熵計算
- 3. 我需要遞歸算法
- 4. C# - 我需要爲最重複數的算法的算法
- 5. 如何計算香農熵和N個變量的互信息
- 6. 詞彙豐富性爲香農熵;蟒
- 7. 無噪信號的香農方程
- 8. 理解數據集的香農熵
- 9. 蟒蛇numpy的香農熵陣列
- 10. 需要算法來解決移用C
- 11. C++ Map:需要智能算法
- 12. 我需要什麼樣的算法?
- 13. 我需要Objective-C語法來計算bmi
- 14. 我需要在C#中
- 15. shannon fano和huffman算法有什麼區別?
- 16. 我需要模C++
- 17. 算法幫助需要
- 18. 需要建議像算法
- 19. 算法需要幫助
- 20. 需要算法的幫助
- 21. 3D旋轉算法需要
- 22. 如何解決在MATLAB帶寬和香農容量
- 23. 梅隆銷售農民的算法
- 24. 算法需要兩次計算差異
- 25. 需要幫助在PHP的MySQL算法
- 26. 需要在組合有效的算法
- 27. 在objective-c中的貝塞爾曲線算法需要調整
- 28. 需要的算法,創建嵌套類在C#中
- 29. 需要在C#
- 30. 需要在C#
您是否試過聯繫香農或法諾? :-) – paxdiablo 2010-04-24 10:01:21
@paxdiablo:香農在2001年去世了,法諾還活着;) – abatishchev 2010-04-24 10:02:32
不,我沒有嘗試,我需要它儘快 我該如何聯繫他們? – 2010-04-24 10:03:08