gpt4 book ai didi

c++返回自定义结构类型-错误

转载 作者:行者123 更新时间:2023-11-28 07:41:40 27 4
gpt4 key购买 nike

我今天开始学习 C++,但目前遇到了一些问题。

我有一个称为数据的自定义结构:

struct data{
int x, y, l;
};

它是一个包含 3 个变量的简单结构。

接下来我运行这个递归函数。尽管如此,它做什么并不重要,因为打印出最终的返回语句会产生正确的结果。

data finds(int x, int y, int length, string s){
//cout << length << endl;
int nx = prev(x, s);
int ny = next(y, s);
if(nx != -1 && ny != -1 && s.at(nx) == s.at(ny)){
finds(nx, ny, length + 2, s);
}
else{

cout << x << y << length << endl;
data vals;
vals.x = x;
vals.y = y;
vals.l = length;
return vals;
}
}

此函数中的 cout 语句产生

068

这是我想要的数字。但是,当我尝试像这样打印此函数的结果时:

464078426865241

这显然是错误的。

我的问题变成了:如何正确地返回结构以产生正确的值。

您可能还需要一些可运行的代码:

#include <iostream>
#include <fstream>
#include <string>
using namespace std;
struct data{
int x, y, l;
};
int next(int i, string s){
//cout << s;
//cout << j;
for(int j = i + 1; j < s.size(); j++){
if(isalnum(s.at(j))){
return j;
}
}
return -1;
}

int prev(int i, string s){
//cout << s;
for(int j = i - 1; j >= 0; j--){
//cout << j;
if(isalnum(s.at(j))){
return j;
}
}
return -1;
}
data finds(int x, int y, int length, string s){
//cout << length << endl;
int nx = prev(x, s);
int ny = next(y, s);
if(nx != -1 && ny != -1 && s.at(nx) == s.at(ny)){
finds(nx, ny, length + 2, s);
}
else{

cout << x << y << length << endl;
data vals;
vals.x = x;
vals.y = y;
vals.l = length;
return vals;
}
}

int main(){
s = "1233321";
data val;
val = finds(3, 3, 2, s);

cout << val.x << val.y << val.l;





}

最佳答案

您忘记返回执行递归的函数:

return finds(nx, ny, length + 2, s);
^^^^

否则不这样做会导致未定义的行为。

关于c++返回自定义结构类型-错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15725149/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com