我正在寫一個大數加函式,使用陣列
#define MAXLEN 10
int * plus(int *a, int *b) {
int *result;
int tmp;
int add = 0;
result = (int *)malloc(MAXLEN); // A breakpoint exception was triggered
for (int i = MAXLEN - 1; i >= 0; i--) {
tmp = a[i] b[i] add;
add = 0;
if (tmp / 10) {
add = tmp / 10;
tmp = tmp % 10;
}
result[i] = tmp;
}
return result;
}
malloc 行總是有例外,但在其他函式中 malloc() 運行良好。
它是怎么發生的?
以下是所有代碼:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAXLEN 10
int * plus(int *a, int *b) {
int *result;
int tmp;
int add = 0;
result = (int *)malloc(MAXLEN);
for (int i = MAXLEN - 1; i >= 0; i--) {
tmp = a[i] b[i] add;
add = 0;
if (tmp / 10) {
add = tmp / 10;
tmp = tmp % 10;
}
result[i] = tmp;
}
return result;
}
void deliver(int *a, int *b) {
for (int i = 0; i < MAXLEN; i ) {
a[i] = b[i];
}
}
void init_int(int *a) {
for (int i = 0; i < MAXLEN; i ) {
a[i] = 0;
}
}
int * numWays(int n) {
int *a, *b, *c, *sum;
int j;
a = (int *)malloc(MAXLEN);
b = (int *)malloc(MAXLEN);
c = (int *)malloc(MAXLEN);
init_int(a);
init_int(b);
init_int(c);
init_int(sum);
a[MAXLEN - 1] = 1;
b[MAXLEN - 1] = 1;
c[MAXLEN - 1] = 2;
for (int i = 0; i < n; i ) {
sum = plus(plus(a, b), c);
deliver(a, b);
deliver(b, c);
deliver(c, sum);
}
return a;
}
int main()
{
int print_flag = 0;
int *num;
num = (int *)malloc(MAXLEN);
num = numWays(4);
for (int i = 0; i < MAXLEN; i ) {
if (num[i]) {
print_flag = 1;
}
if (print_flag) {
printf("%d", num[i]);
}
}
printf("\n");
return 0;
}
這是一個問題,如果青蛙每次可以跳 1、2 或 3 步,它可以跳 n 步,我想要確切的數字。
uj5u.com熱心網友回復:
改變:
result = (int *)malloc(MAXLEN);
對此:
result = malloc(MAXLEN * sizeof(int))
因為您想動態分配等于大小的記憶體int,所以MAXLEN。
malloc 行總是有例外..
你的意思是編譯錯誤。例外是一個更高級的概念,您可以稍后學習。
PS:我會轉換malloc的結果嗎?不。
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/409621.html
標籤:
