gpt4 book ai didi

c++ - 按字母顺序嵌套数据结构 C++

转载 作者:搜寻专家 更新时间:2023-10-31 01:40:29 24 4
gpt4 key购买 nike

我试图让我的代码以更有效的方式按字母顺序对嵌套数据结构的元素进行排序。这是我的一段代码:

 struct famous {
string name;
string emp;
int proes;
int mins;
string mit;
};

struct personal {
famous per[500];
int np;
};

void delete(personal & p, int ndx){
int mid = p.np;
for (int i=ndx; i<mid-1; i++){
p.per[i].name = p.per[i+1].nom;
p.per[i].emp = p.per[i+1].emp;
p.per[i].mins = p.per[i+1].mins;
p.per[i].mit = p.per[i+1].mit;
}
p.np = mid-1;
}

void sort(personal & p){
string tmp;
int pers;
personal vtmp;
pers = p.np;
tmp = p.per[0].name;
for (int pos=0; pos<pers; pos++){
for (int ndx=1; ndx<p.np; ndx++){
if (tmp>p.per[ndx].name){tmp=p.per[ndx].name;}
}
vtmp.per[pos] = p.per[ndx]; //line 107
deletePers(p,ndx);
tmp = p.per[0].name;
}
}

当我尝试编译代码时,问题来了,我得到了这个:

D:\main.cpp|107|error: name lookup of 'ndx' changed for ISO 'for' scoping [-fpermissive]|

我该如何解决这个问题?

先谢谢你!

最佳答案

试试这个功能

void sort(personal & p){
int ndx =1; // declare ndx at the starting of sor function
string tmp;
int pers;
personal vtmp;
pers = p.np;
tmp = p.per[0].name;
for (int pos=0; pos<pers; pos++){
for (ndx=1; ndx<p.np; ndx++){ // remove int here
if (tmp>p.per[ndx].name){tmp=p.per[ndx].name;}
}
vtmp.per[pos] = p.per[ndx]; //line 107
deletePers(p,ndx);
tmp = p.per[0].name;
}
}

当你使用 for (int ndx=1; ndx<p.np; ndx++){

范围ndx将仅保留在 for 循环内,因此无法在 for 循环外使用它。
所以声明ndx会很好在循环之外。

关于c++ - 按字母顺序嵌套数据结构 C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29741640/

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