如何将C ++转换为C? [英] How to I convert C++ to C?
本文介绍了如何将C ++转换为C?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
#include <vector>
#define max(a,b) ((a>b)?(a):(b))
using namespace std;
int solution(vector<int> sticker)
{
int answer = 0;
int size = 4;
int i;
if (sticker.size() == 1) return sticker[0];
while (size--)
{
int result[100000] = { 0, };
int tmp_max = 0;
result[0] = sticker[0];
result[1] = sticker[1];
result[2] = sticker[2] + result[0];
for (i = 3; i < sticker.size() - 1; i++)
{
tmp_max = max(result[i - 2], result[i - 3]);
result[i] = sticker[i] + tmp_max;
}
answer = max(answer, result[sticker.size() - 2]);
sticker.push_back(sticker[0]);
sticker.erase(sticker.begin());
}
return answer;
}
我的尝试:
只是同样的代码.....
What I have tried:
JUST SAME CODE.....
#include <vector>
#define max(a,b) ((a>b)?(a):(b))
using namespace std;
int solution(vector<int> sticker)
{
int answer = 0;
int size = 4;
int i;
if (sticker.size() == 1) return sticker[0];
while (size--)
{
int result[100000] = { 0, };
int tmp_max = 0;
result[0] = sticker[0];
result[1] = sticker[1];
result[2] = sticker[2] + result[0];
for (i = 3; i < sticker.size() - 1; i++)
{
tmp_max = max(result[i - 2], result[i - 3]);
result[i] = sticker[i] + tmp_max;
}
answer = max(answer, result[sticker.size() - 2]);
sticker.push_back(sticker[0]);
sticker.erase(sticker.begin());
}
return answer;
}
推荐答案
很少需要更改 - 只有访问贴纸矢量的部分。由于vector类维护自己的计数,你必须在C中做自己。以下是C代码的相关更改:
Very little of it needs to change - only the parts that access the sticker vector. Since the vector class maintains its own count, you have to do yourself in C. Here are the relevant changes for C code :
int solution( int sticker[], int stickerCount )
{
...
int last = stickerCount - 1;
if( last < 0 )
return -1; // error - empty array
if( last == 0 )
return sticker[0];
while( size-- )
{
...
for( i = 3; i < last; i++ )
{
...
}
...
answer = max( answer, result[ last - 1 ] );
sticker[ stickerCount ] = sticker[ 0 ];
memmove( sticker, &sticker[1], stickerCount * sizeof( int ) );
}
...
}
这篇关于如何将C ++转换为C?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文