早教吧作业答案频道 -->其他-->
谁能帮我看下这个程序问题出在哪?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.
这位兄弟..你给的分太少了...应该不会有人这么费力的为你解答吧!呵呵 ...!
看了 谁能帮我看下这个程序问题出在...的网友还看了以下:
正定矩阵一个矩阵乘以它的转置一定正定吗?如果不是,那要满足什么条件才成立?如果这个矩阵是一系列初等 2020-06-10 …
下列说法正确的是?a.零矩阵一定是方阵b.可转置的矩阵一定是方阵c.数量矩阵一定是方阵d.若A与A 2020-06-10 …
谁能帮我看下这个程序问题出在哪?function[variancebsbkbnsigma]=tra 2020-06-21 …
你在伞里吗阅读答案,不要复制!文中第三段说到“可就是这一阵一阵的温暖,让我寒雨里的心一阵一阵战栗! 2020-07-03 …
您好,请问满足如下条件的矩阵是否可以证明他一定满秩1、对角线上的值,大于这一行其他列之和2、这个矩 2020-07-08 …
1、同学们在操场上摆出一个正方形方阵,这个正方形的第一横行和第一竖列的人数之和是17人,这个方阵一 2020-07-15 …
镜片和镜片叠加之后的度数是两眼镜的度数相加吗?一个255度的眼镜加上一个150度的眼镜是不是等于4 2020-07-19 …
谁帮忙看下这个行列式的题,算法不同结果不一样,哪个错了?就是这个题,用初等变换算的结果和答案一样, 2020-08-02 …
一个实心方阵,最外层一共有20人.请问:(1)最外层每边有多少人?这个方阵一共有多少人?(2)如果要 2020-11-02 …
秩为1的矩阵一定和对角矩阵相似吗请简要说明理由,1.首先问题中不应该为矩阵,而是“方阵”.2.方阵规 2020-12-01 …