struct HP { int p[505], len; HP() { memset(p, 0, sizeof p); len = 0; } //这是构造函数,用于直接创建一个高精度变量 void print() { printf("%d", p[len]); for (int i = len - 1; i > 0; i--) { if (p[i] == 0) { printf("0000"); continue; } for (int k = 10; k * p[i] < Mod; k *= 10) printf("0"); printf("%d", p[i]); } } //四位压缩的输出 } f[MAXN][MAXN], base[MAXN], ans;将结构体成员函数转换成类类型函数
时间: 2024-01-16 11:04:10 浏览: 64
将结构体成员函数转换为类类型函数需要将结构体的定义改为类的定义,并添加类的访问修饰符(public、private、protected)。同时,成员函数的定义也需要做相应的修改。
下面是将结构体 HP 转换为类类型函数的代码:
```
class HP {
public:
int p[505], len;
HP() {
memset(p, 0, sizeof p);
len = 0;
}
//这是构造函数,用于直接创建一个高精度变量
void print() {
printf("%d", p[len]);
for (int i = len - 1; i > 0; i--) {
if (p[i] == 0) {
printf("0000");
continue;
}
for (int k = 10; k * p[i] < Mod; k *= 10)
printf("0");
printf("%d", p[i]);
}
} //四位压缩的输出
};
HP f[MAXN][MAXN], base[MAXN], ans;
```
在上面的代码中,将结构体改为了类,并将 HP 的成员变量和成员函数都声明为 public 类型。
相关问题
#include <stdio.h> #include <stdbool.h> struct bign{ int d[200]; int len; int flag; }; typedef struct bign BigNum; void init(BigNum *a) { memset(a->d,0,sizeof(a->d)); a->len = 0; a-> flag = 1; } BigNum str_to_num(const char str[]) { BigNum res; init(&res); int len = strlen(str); res.len = len; for(int i = 0;i < len;i++) { if(str[len - 1-i] == '-') { res.len --; res.flag = -1; break; } else { res.d[i] = str[len - 1 - i] - '0'; } } return res; } bool is_zero(const BigNum *a) { if(a->len == 1 && a-> d[0] == 0) { return true; } else return false; } //比较绝对值得大小 int bign_cmp(const BigNum *a,const BigNum *b) { if(a->len > b-> len) { return 1; } else if(a->len < b->len) { return -1; } else { for(int i = a-> len-1;i >= 0;i --) { if(a->d[i] > b->d[i]) { return 1; } else if(a->d[i]<b->d[i]) return -1; } } return 0; } //高精度加法 BigNum_add(const BigNum *a,const BigNum *b) { BigNum res; bign(&res); int len; len = (a->len>b->len)?a->len:b->len; for(int i = 0;i < len;i++) { res.d[i] += a->d[i] + b->d[i]; if(res.d[i] >= 10) { res.d[i+1]++; res.d[i] -= 10; } } if(res.d[len] != 0) { len++; } res.len = len; res.flag = 1; return res; } BigNum_sub(BigNum *a,BigNum *b) { BigNum res; bign(&res); int len; if(cmp(a,b) < 0) { BigNum *tmp = a; a =b; b = tmp; res.flag = -1; } else { res.flag = 1; } len = a->len; for(int i = 0;i < len;i++) { if(a->d[i]<b->d[i]) { a->d[i+1]--; a->d[i] +=10; } res.d[i] = a->d[i] - b->d[i]; } while(len > 1 && res.d[len-1] == 0) { len--; } res.len = len; return res; } void print_bignum(const BigNum *a) { if(a->flag<0) { printf("-"); } for(int i = a->len-1;i>=0;i--) { printf("%d",a->d[i]); } printf("\n"); } int main() { char a, b; scanf("%s %s",&a,&b); init(a); BigNum_add(a,b); print_bignum(a); return 0; }完善该段代码
这段代码存在一些问题,需要进行修改和完善才能正常运行,我给您列举一下:
1. 在主函数中,您使用了字符变量 a 和 b 来输入两个大数,但实际上应该使用字符串类型的数组才能正确地输入大数,所以需要修改为 char a[200], b[200];
2. 在主函数中,您调用了 BigNum_add 函数来进行高精度加法,但是没有接收返回值,需要修改为 BigNum res = BigNum_add(&a, &b);
3. 在 BigNum_sub 函数中,您调用了 cmp 函数,但是该函数并未在代码中定义,需要修改为 bign_cmp 函数;
4. 在 BigNum_add 函数中,您使用了错误的函数名 bign,应该改为 init。
根据以上问题,完善后的代码如下:
将这段代码变成用matlab实现#include<bits/stdc++.h> using namespace std; struct Pos{ int p; int w; int s; int v; int Get(){ return p*8+w*4+s*2+v; } }; Pos Change(Pos a,int i){ if(i==0) a.p=abs(a.p-1); else if(i==1){ //商人和狼 if(a.p==a.w)a.w=abs(a.w-1); a.p=abs(a.p-1); } else if(i==2){ //商人和羊 if(a.p==a.s)a.s=abs(a.s-1); a.p=abs(a.p-1); } else { //商人和菜 if(a.p==a.v)a.v=abs(a.v-1); a.p=abs(a.p-1); } return a; } int Judge(Pos a) { if(a.p==a.s||(a.p==a.w&&a.w==a.v)) return true; return false; } int Judge(Pos a,Pos b){ if(a.w==b.w&&a.p==b.p&&a.s==b.s&&a.v==b.v ) return true; return false; } void GetLength(Pos start,Pos a,Pos *prev){ vector<Pos> path; Pos p = a; path.push_back(p); while (!Judge(p,start)) { path.push_back(prev[p.Get()]); p = prev[p.Get()]; } cout << "Shortest path length: " << path.size()<< endl; cout << "Shortest path: \n"; for (int i = path.size() - 1; i >= 0; i--) { cout << "(" << path[i].p << "," << path[i].w << "," << path[i].s << "," << path[i].v << ") \n"; } cout << endl; } void BFS(Pos start, Pos goal, int* f) { queue<Pos> q; int len = 0; Pos prev[16]; // 用于记录每个状态是由哪个状态转移而来 memset(f, 0, sizeof(f)); q.push(start); prev[start.Get()] = start; f[start.Get()] = 1; while (!q.empty()) { Pos a; a = q.front(); q.pop(); len++; if (Judge(a, goal)) { return GetLength(start,a,prev); } else { for (int i = 0; i < 4; i++) { Pos b; b = Change(a, i); if (Judge(b) && f[b.Get()] == 0) { q.push(b); f[b.Get()] = 1; prev[b.Get()] = a; // 记录当前状态是由哪个状态转移而来 } } } } } int main(){ int pathlength,f[16]; Pos start; Pos goal; start.p=0; start.s=0; start.w=0; start.v=0; goal.p=1; goal.s=1; goal.v=1; goal.w=1; for(int i=0;i<16;i++) f[i]=0; BFS(start,goal,f); return 0; }
好的,以下是用 Matlab 实现的代码:
```matlab
% 定义结构体 Pos
Pos.p = 0;
Pos.w = 0;
Pos.s = 0;
Pos.v = 0;
% 定义函数 Change
function a = Change(a, i)
if i == 0
a.p = abs(a.p - 1);
elseif i == 1
if a.p == a.w
a.w = abs(a.w - 1);
end
a.p = abs(a.p - 1);
elseif i == 2
if a.p == a.s
a.s = abs(a.s - 1);
end
a.p = abs(a.p - 1);
else
if a.p == a.v
a.v = abs(a.v - 1);
end
a.p = abs(a.p - 1);
end
end
% 定义函数 Judge
function flag = Judge(a, b)
if a.p == b.p && a.w == b.w && a.s == b.s && a.v == b.v
flag = true;
else
flag = false;
end
end
% 定义函数 GetLength
function GetLength(start, a, prev)
path = [];
p = a;
path = [path, p];
while ~Judge(p, start)
path = [path, prev(p.p*8+p.w*4+p.s*2+p.v+1)];
p = prev(p.p*8+p.w*4+p.s*2+p.v+1);
end
disp(['Shortest path length: ', num2str(length(path))]);
disp('Shortest path:');
for i = length(path):-1:1
disp(['(', num2str(path(i).p), ',', num2str(path(i).w), ',', num2str(path(i).s), ',', num2str(path(i).v), ')']);
end
end
% 定义函数 BFS
function BFS(start, goal, f)
q = [];
len = 0;
prev = repmat(Pos, 16, 1);
memset(f, 0, 16);
q = [q, start];
prev(start.p*8+start.w*4+start.s*2+start.v+1) = start;
f(start.p*8+start.w*4+start.s*2+start.v+1) = 1;
while ~isempty(q)
a = q(1);
q(1) = [];
len = len + 1;
if Judge(a, goal)
GetLength(start, a, prev);
return
else
for i = 0:3
b = Change(a, i);
if Judge(b) && f(b.p*8+b.w*4+b.s*2+b.v+1) == 0
q = [q, b];
f(b.p*8+b.w*4+b.s*2+b.v+1) = 1;
prev(b.p*8+b.w*4+b.s*2+b.v+1) = a;
end
end
end
end
end
% 主函数
start.p = 0;
start.s = 0;
start.w = 0;
start.v = 0;
goal.p = 1;
goal.s = 1;
goal.v = 1;
goal.w = 1;
f = zeros(1, 16);
BFS(start, goal, f);
```
在上面的示例中,我们首先定义了结构体 `Pos`,并分别初始化其四个属性。接着定义了三个函数 `Change`、`Judge` 和 `GetLength`,分别对应原 C++ 代码中的三个函数。最后定义了主函数,在其中初始化起点和终点,并创建一个长度为16的数组 `f` 用于记录状态是否已经访问过。然后调用 `BFS` 函数进行广度优先搜索,找到从起点到终点的最短路径。
阅读全文