如何解决我无法解决此细分错误
此代码应读取行和列的未定义长度的位图,例如
25 6
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
第一个数字(25)是图像中像素的总数,第二个数字(6)是灰色阴影的数量
通过“加载图像”功能将其保存到指针f中,然后使用其他功能对其进行分析。
例如,它应该返回每个灰色阴影的频率。
数据细化工作正常,但是功能边界给我分割错误。
它应该使用我给函数提供的值“ val”来切换像素图边界上的每个值。在这种情况下为零
我该如何解决?
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include<math.h>
void read_dim_grey(FILE *fin,int *p,int *g)
{
fscanf(fin,"%d %d",p,g);
}
int **img_alloc(int n_row,int n_col)
{
int **p;
int i;
if ((p = malloc(n_row * sizeof(*p))) == NULL) {
printf("not enough memory !\n");
exit(-1);
}
for (i = 0; i < n_row; i++) {
p[i] = malloc(n_col * sizeof(*p));
if (p[i] == NULL) {
printf("not enough memory\n");
exit(-1);
}
}
return p;
}
int *vect_alloc(int n)
{
int *p;
p = malloc(n * sizeof(*p));
if (p == NULL) {
printf("not enough memory !\n");
exit(-1);
}
return p;
}
void load_img(int **img_in,int n_row,int n_col,FILE *fin)
{
int i,j;
for(i = 0; i < n_row; i++)
for (j = 0; j < n_col; j++) {
fscanf(fin,"%d",img_in[i] + j);
}
}
void calculate_freq(int **img,int *f)
{
int i,j;
for(i = 0; i < n_row; i++)
for (j = 0; j < n_col; j++)
f[img[i][j]]++;
}
void frequence(int *freq,int n)
{
int i;
for(i = 0; i < n; i++) {
printf("%d\n",freq[i]);
}
}
void filter(int *freq,int n,int val)
{
int i,tot = 0;
for(i = 0; i < n; i++) {
if (freq[i] == val) {
printf("%d\n",i);
tot++;
}
}
if (tot == 0)
printf("NESSUNO\n");
}
void missing(int *freq,int n)
{
filter(freq,n,0);
}
void prevalent(int *freq,int n)
{
int i,max = freq[0];
for(i = 1; i < n; i++) {
if(freq[i] > max)
max = freq[i];
}
filter(freq,max);
}
double average( int **img,int n_col)
{
int i,j;
double somma = 0;
for(i = 0; i < n_row; i++)
for (j = 0; j < n_col; j++)
somma += img[i][j];
return somma/(n_row*n_col);
}
void tozero(int *f,int n)
{
int i;
for(i = 0; i < n; i++)
f[i] = 0;
}
void borders(int **img,j;
for(j = 0; i < n_col; j++)
img[0][j] = val;
for(j = 0; i < n_col; j++)
img[n_row - 1][j] = val;
for(i = 1; i < n_row ; i++) {
img[i][0] = val;
img[i][n_col - 1] = val;
}
}
int main(int argc,char *argv[])
{
FILE *fin;
int n_row,n_col,n_pixel,n_grey,prof;
int **img_in,*freq;
if (argc != 2) {
puts("e niente,non sono abbaastanza gli aargomenti,mannaggia");
}
if (!(fin = fopen(argv[1],"r"))) {
printf("uso: %s <img_input> \n",argv[0]);
exit(1);
}
read_dim_grey(fin,&n_pixel,&prof);
n_grey = (int)pow(2,prof);
n_row = n_col = sqrt(n_pixel);
img_in = img_alloc(n_row,n_col);
load_img(img_in,n_row,fin);
freq = vect_alloc(n_grey);
calculate_freq(img_in,freq);
printf("[FREQUENZE]\n");
frequence(freq,prof);
printf("[MANCANTI]\n");
missing(freq,prof);
printf("[PREVALENTI]\n");
prevalent(freq,prof);
printf("[MEDIA]\n");
printf("%.2lf\n",average(img_in,n_col));
borders(img_in,0);
//tozero(freq,n_grey);
//calculate_freq(img_in,freq);
//printf("FREQUENZE AGGIORNATE\n");
//frequence(freq,n_grey);
//printf("[MEDIA AGGIORNATA]\n");
//printf("%.2lf \n",n_col));
//
return 0;
}
解决方法
您遇到了段错误,因为变量p为int **
,并且您想像这样初始化p
。
p = malloc(n_row * sizeof(*p);
或者就像我在您的p变量是``int **`''之前所说的那样,为了修复您的错误,您应该将其记录下来:
p = malloc(n_row * sizeof(**p);
对sizeof的定义:
Sizeof是C或C ++中常用的运算符。它是一个编译时一元运算符,可用于计算其操作数的大小。 sizeof的结果是无符号整数类型,通常用size_t表示。 sizeof可以应用于任何数据类型,包括基本类型,例如整数和浮点类型,指针类型,或复合数据类型,例如Structure,union等。
链接以更好地理解:https://www.geeksforgeeks.org/is-sizeof-for-a-struct-equal-to-the-sum-of-sizeof-of-each-member/
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。