编译怎么有一处syntax error:']'

ratrat 2001-11-09 10:30:52
void Filter( list<IntArray>& combs)
{
list<IntArray>::iterator iter;
for( iter = combs.begin(); iter != combs.end(); )
{
IntArray& array = *iter;
num = 1;
for( int i = 1; i < array.size(); i++ ){
for( int j = 1; j < array.size(); j++ )
if( array[i] > array[j] )
{array[]=array[i] - array[j];}//好象array[]有问题,不知怎样办?
}
int count = 0;
for( int i = 1; i < array.size(); i++ ){
for( int j = 1; j < array.size(); j++ )
if( array[i] == array[j] )
{ break;}
else
{ count++;}
}
}


list<IntArray>::iterator old_iter;
if( count != 10 ) {
old_iter = iter;
iter++;
combs.erase(old_iter);
} else {
iter++;
}
}
}
我的意思是:把一数组的大数减去小数,形成另一数组,在另一数组中去掉相同数并统计个数,我不知怎样设另一数组,怎样运用。请指教。
...全文
66 点赞 收藏 8
写回复
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
ratrat 2001-11-09
谢谢各位,我在网吧,先给分,回去调试,如果有问题再请教大家。
回复
ratrat 2001-11-09
if( count != 10 )指新产生数组中如果元素个数不为10则删去此数组;
num = 1;是我笔误应删去;
是stl;
回复
ydogg 2001-11-09
我不知道你具体的数据结构,简单猜测了一下,随便看看吧


void Filter( list<IntArray>& combs)
{
IntArray temp;
list <IntArray> &lResult;
list<IntArray>::iterator iter;
for( iter = combs.begin(); iter != combs.end();iter++)
{
IntArray& array = *iter;
num = 1;
for( int i = 1; i < array.size(); i++ ){
for( int j = 1; j < array.size(); j++ )
if( array[i] > array[j] ) {
int d = array[i] - array[j];
//我不知道你的IntArray是什么类型如何操作(应该是stl的东西吧),简单表示一下
temp.PushBack(d);
}
}
int count = 0;//存放出现相同值之前的长度
for( int i = 1; i < temp.size(); i++ ){
for( int j = 1; j < temp.size(); j++ ){
if( temp[i] == temp[j] )
break;
else
count++;
}
temp.erase(j);
}
lResult.pushback(temp);
}
/*list<IntArray>::iterator old_iter;
if( count != 10 ) { //这是什么判断?
old_iter = iter;
iter++;
combs.erase(old_iter);
} else {
iter++;
}*/
}
回复
jason802 2001-11-09
k没有赋值

还是不正确

回复
jason802 2001-11-09
同意楼上。

回复
ratrat 2001-11-09
那我改成
int k;
array[k]=array[i] - array[j];
其余的不变,对吗?还有其余的错吗?
回复
ynyn 2001-11-09
array[]=array[i] - array[j];这一句明显是错误的,你必须给前面的array[]指定一个下标,不能把一个整数赋给给一个整数数组,只能把它赋给数组中的一个元素
回复
ratrat 2001-11-09
我回去调试有一大堆error,我把程序完整贴出,请麻烦看一下Filter部分错在那里,
#include <iostream>
#include <vector>
#include <list>
using namespace std;

typedef vector<int> IntArray;

// 回溯搜索生成组合
void Search(int m, int n, int depth, IntArray& mark, IntArray& L, list<IntArray>& result)
{
if( depth == n ) {
result.push_back(L);
} else {
int begin;
if( depth == 0 ) {
begin = 0;
} else {
begin = L[depth-1];
}
for( int i = begin; i < m; i++ )
if( mark[i] == 0 ) {
mark[i] = 1;
L[depth] = i + 1;
Search( m, n, depth+1, mark, L, result );
mark[i] = 0;
}
}
}


// 生成从m个数中取出n个数的组合数C(m,n)
// 结果在result中返回
void Combination(int m, int n, list<IntArray>& result)
{
if( m < n ) return;

IntArray mark(m); // 用来标记某个数字是否用过了

for( int i=0; i < m; i++ ) { // 初始化mark
mark.push_back(0);
}

IntArray comb(n); // 存储一组组合数
comb.resize(n);

Search(m, n, 0, mark, comb, result);
}


// 打印组合数
void Print(list<IntArray>& combs)
{
cout << "result is : " << endl;

list<IntArray>::iterator iter;
for( iter = combs.begin(); iter != combs.end(); iter++ )
{
IntArray& array = *iter;
for( int i = 0; i < array.size(); i++ )
cout << array[i] << " ";
cout << endl;
}
}





void Filter( list<IntArray>& combs)
{
IntArray temp;
list <IntArray> &lResult;
list<IntArray>::iterator iter;
for( iter = combs.begin(); iter != combs.end();iter++)
{
IntArray& array = *iter;
num = 1;
for( int i = 1; i < array.size(); i++ ){
for( int j = 1; j < array.size(); j++ )
if( array[i] > array[j] ) {
int d = array[i] - array[j];

temp.PushBack(d);
}
}
int count = 0;//存放出现相同值之前的长度
for( int i = 1; i < temp.size(); i++ ){
for( int j = 1; j < temp.size(); j++ ){
if( temp[i] == temp[j] )
break;
else
count++;
}
temp.erase(j);
}
lResult.pushback(temp);
}
list<IntArray>::iterator old_iter;
if( count != 10 ) {
old_iter = iter;
iter++;
combs.erase(old_iter);
} else {
iter++;
}
}

int main()
{

int m, n;
cout << "input m : ";
cin >> m;
cout << "input n : ";
cin >> n;

list<IntArray> result;
Combination( m, n, result );
Filter( result);
Print( result );
return 0;
}
回复
发动态
发帖子
数据结构与算法
创建于2007-08-27

3.2w+

社区成员

数据结构与算法相关内容讨论专区
申请成为版主
社区公告
暂无公告