早教吧作业答案频道 -->其他-->
谁能帮我看下这个程序问题出在哪?function[variancebsbkbnsigma]=trait(I)n=size(I,1)*size(I,2);%n为矩阵中元素个数.m=sum(I(:))/n;%m为灰度平均值,是一个标量,I是图像矩阵A=reshape(I,1,n);p=[];fori=0:255%p从0到
题目详情
谁能帮我看下这个程序问题出在哪?
function [variance bs bk bn sigma]=trait(I)
n=size(I,1)*size(I,2); %n为矩阵中元素个数.
m=sum(I(:))/n; %m为灰度平均值,是一个标量,I是图像矩阵
A=reshape(I,1,n);
p=[];
for i=0:255 %p从0到L-1的各个灰度出现的频率,是一个向量
for j=1:n %获取灰度i的像素个数
s=0;
if(A(j)==i)
s=s+1;
end
end
p=[p,s./n];
variance=0; %方差
variance=variance+(i-m).^2.*p(i+1);
bs0=0; %偏斜度
bs0=bs0+(i-m).^3*p(i+1);
bs=bs0./(sqrt(variance)).^3;
bk0=0; %突出度
bk0=bk0+(i-m).^4*p(i+1);
bk=bk0./(variance).^2;
bn=0; %能量
bn=bn+p(i+1)*p(i+1);
sigma=0; %绝对值
sigma=sigma+abs(i-m)*p(i+1);
end
function [variance bs bk bn sigma]=trait(I)
n=size(I,1)*size(I,2); %n为矩阵中元素个数.
m=sum(I(:))/n; %m为灰度平均值,是一个标量,I是图像矩阵
A=reshape(I,1,n);
p=[];
for i=0:255 %p从0到L-1的各个灰度出现的频率,是一个向量
for j=1:n %获取灰度i的像素个数
s=0;
if(A(j)==i)
s=s+1;
end
end
p=[p,s./n];
variance=0; %方差
variance=variance+(i-m).^2.*p(i+1);
bs0=0; %偏斜度
bs0=bs0+(i-m).^3*p(i+1);
bs=bs0./(sqrt(variance)).^3;
bk0=0; %突出度
bk0=bk0+(i-m).^4*p(i+1);
bk=bk0./(variance).^2;
bn=0; %能量
bn=bn+p(i+1)*p(i+1);
sigma=0; %绝对值
sigma=sigma+abs(i-m)*p(i+1);
end
▼优质解答
答案和解析
d hot(struct stu a[5]);
struct stu
{
int num;
char *name;
int score[3];
}boy[5];
void main()
{
int i,j;
for(i=0;i<5;i++)
{
printf("请输入学生的学号:");
scanf("%d",&boy[i].num);
printf("请输入学生的姓名:");
scanf("%s",boy[i].name);
printf("请输入三门该生成绩:");
for(j=0;j<3;j++)
scanf("%d",&boy[i].score[j]);
}
hot(boy);
// return 0;
}
void hot(struct stu a[5])
{
int i,j;
for(i=0;i<5;i++)
printf("学号为:%d",a[i].num);
printf("姓名为:%s",a[i].name);
for(j=0;j<3;j++)
printf("成绩为%d",a[i].score[j]);
}
这是我修改后的程序...你仔细看看和你的有哪些不同的!
你的错误主要有以下几大点:
1.在void main()中.你出现了return 0语句.这是不对的.void说明无返回值..
2.hot(boy); 函数调用时,不必再次输入类型名!而且...形参以"数组"的形式给出(事实上是指针形式),实参必须要传递地址.你原来的boy[5]是元素!
3.在最后hot函数定义中...下面应该是a[i].XX,而不是boy[i].XX
4.在函数中的类型.是struct stu.不是struct std.
这位兄弟..你给的分太少了...应该不会有人这么费力的为你解答吧!呵呵 ...!
struct stu
{
int num;
char *name;
int score[3];
}boy[5];
void main()
{
int i,j;
for(i=0;i<5;i++)
{
printf("请输入学生的学号:");
scanf("%d",&boy[i].num);
printf("请输入学生的姓名:");
scanf("%s",boy[i].name);
printf("请输入三门该生成绩:");
for(j=0;j<3;j++)
scanf("%d",&boy[i].score[j]);
}
hot(boy);
// return 0;
}
void hot(struct stu a[5])
{
int i,j;
for(i=0;i<5;i++)
printf("学号为:%d",a[i].num);
printf("姓名为:%s",a[i].name);
for(j=0;j<3;j++)
printf("成绩为%d",a[i].score[j]);
}
这是我修改后的程序...你仔细看看和你的有哪些不同的!
你的错误主要有以下几大点:
1.在void main()中.你出现了return 0语句.这是不对的.void说明无返回值..
2.hot(boy); 函数调用时,不必再次输入类型名!而且...形参以"数组"的形式给出(事实上是指针形式),实参必须要传递地址.你原来的boy[5]是元素!
3.在最后hot函数定义中...下面应该是a[i].XX,而不是boy[i].XX
4.在函数中的类型.是struct stu.不是struct std.
这位兄弟..你给的分太少了...应该不会有人这么费力的为你解答吧!呵呵 ...!
看了 谁能帮我看下这个程序问题出在...的网友还看了以下:
1.Don't do it _____. OK.I won't A.like that B.lik 2020-05-16 …
youhavebeenaskedtocreateasubnetthatsupports16host 2020-05-22 …
IP地址211.81.12.129/28的子网掩码可写为()A.255.255.255.192B.2 2020-05-23 …
202.192.33.160/28的子网掩码是( )。A.255.255.255.240B.255. 2020-05-23 …
10.16.210.48/21的子网掩码是( )。A.255.255.248.0B.255.255. 2020-05-23 …
有关子网掩码的计算将网络10.20.0.0/18划分为尽量多的子网,每个子网至少支持60台主机,则 2020-07-08 …
要设置一个子网掩码使192.168.0.94和192.168.0.116不在同一网段,使用的子网掩 2020-07-17 …
求解释关于网络问题1、如果用户网络需要划分成5个子网,每个子网最多20台主机,则适用的子网掩码是( 2020-07-19 …
在一条点对点的链路上,为了减少地址的浪费。子网掩码应该指定为A.255.255.255.252B. 2020-07-19 …
判断下列子网掩码错在哪里A:255.255.240B:7.0.0.0C:255.255.242D: 2020-07-19 …