日本无码中文字幕片|日本精品在线观看无码视频|国产精品免费啪啪|Av无码一区二区|亚洲在线黄片免费观看|亚洲日韩中文字幕在线观看|熟女激情乱伦在线观看a黄片|成年人观看毛片网址|AV色色色色日韩性草|国产高清无码免费

英語六級(jí)考試流程「」

時(shí)間:2025-11-18 06:55:37 報(bào)考指南 我要投稿

2015年英語六級(jí)考試流程「匯編」

二筆只有三道題,分值分別為30, 30, 40,題分別如下:
1、實(shí)現(xiàn)strtol函數(shù),其原型如為int strtol(const char *num_str, char **endptr, int base),num_str存放待轉(zhuǎn)換的字符串,可以是負(fù)數(shù)也可以是正數(shù);endptr指向第一個(gè)非法字符的地址,如果endptr為NULL則不指向第一個(gè)非法字符的地址;base用于指示進(jìn)制,若base為0,則根據(jù)num_str的指示來轉(zhuǎn)換。函數(shù)必須檢查溢出,如果正數(shù)溢出,返回INT_MAX;若負(fù)數(shù)溢出,返回INT_MIN。
2、一億個(gè)數(shù)找最大的1000個(gè)數(shù),要求效率高占用內(nèi)存少。函數(shù)原型為:find_max_data(int* source_data, int* max_data),其中source_data是存放一億個(gè)數(shù)的數(shù)組,max_data用于存放其中最大的1000個(gè)數(shù)。
3、將一個(gè)集合拆分成兩個(gè)不相交的子集,兩個(gè)子集元素之和相等,如{1, 2, 3, 4, 5, 6, 7},拆分成:
{2, 5, 7}, {1, 3, 4, 6}
給出一個(gè)集合,求所有符合上面要求的拆分,效率最高分越高,函數(shù)原型為int cal_num(int n);

2015年英語六級(jí)考試流程「匯編」

第三題:
利用回溯剪枝法
空間復(fù)雜度:O(n) 棧的最大深度也就是n了
時(shí)間復(fù)雜度:接近于O(2^n-1), 因?yàn)楸举|(zhì)上程序時(shí)一個(gè)遍歷樹的過程,如果沒有剪枝,那么樹是一個(gè)滿二叉樹,結(jié)點(diǎn)共2^n-1個(gè),也就要遍歷2^n-1次。雖然剪枝,但速度估計(jì)仍是 2^n次方級(jí)別的。
試了下,調(diào)用cal_num(104),好久了結(jié)果都沒有出來。。。

不知用上DP算法會(huì)不會(huì)好點(diǎn),不過聽說回溯法怎么弄效率都跟不上,最好用遞推?
在哪聽說的?

/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/
/pic/p>

#ifndef __DIVIDE_SET_H__
#define __DIVIDE_SET_H__

/pic/> /pic/> void divide_set( int set[], int label[], int len, int i_set, int value );

/pic/> void cal_num( int n );

#endif


/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/pic/
/pic/p>

#include "stdafx.h"
#include "divide_set.h"

#include <iostream>

using namespace std;

/pic/> void divide_set( int set[], int label[], int len, int i_set, int value )
{
 /pic/>  if ( value == 0 )
 {
  cout<<"{ ";
  for ( int i=0; i<len; ++i )
  {
   if ( label[i] )
   {
    cout<<set[i]<<" ";
   }
  
  }
  cout<<"} ";
  cout<<" , { ";
  for ( int i=0; i<len; ++i )
  {
   if ( 0 == label[i] )
   {
    cout<<set[i]<<" ";
   }
  }
  cout<<"} ";
  cout<<endl;
  return;
 }

 if ( i_set >= len || value <0)
 {
  return;
 }

 /pic/>  label[i_set] = 1;
 divide_set( set, label, len, i_set+1, value-set[i_set] );
 
 /pic/>  label[i_set] = 0;
 divide_set( set, label, len, i_set+1, value );
}

void cal_num( int n )
{
 int* set = new int[n];
 int* label = new int[n];

 /pic/>  int sum_value = 0;
 for ( int i=0; i<n; ++i )
 {
  set[i] = i+1;
  sum_value += set[i];
 }
 memset( label, 0, n*sizeof(int) );

 /pic/>  if( sum_value%2 == 0 )
  divide_set( set, label, n, 0, sum_value/2 );

 delete[] set;
 delete[] label;
}

/pic/p>

/pic/> /pic/> /pic/> void divide_set( int set[], int label[], int len, int i_set, int value );

/pic/> int divide_set_v2( int set[], int len, int i_set, int value );

int divide_set_v3( int set[], int len, int** bpHistory, int i_set, int value );

int divide_set_v4( int set[], int len, std::vector< std::vector<int> > &bpHistory, int i_set, int value );

class Bin;
int divide_set_v5( int set[], int len, Bin &bpHistory, int i_set, int value );

/pic/> void cal_num( int n );

/pic/> int cal_num_v2( int n );

/pic/> int cal_num_v3( int n );

/pic/> int cal_num_v4( int n );

/pic/> int cal_num_v5( int n );

/pic/> long getSetsNum1(int n);

void test_cal_num();

/pic/p>

int divide_set_v2( int set[], int len, int i_set, int value )
{
 if ( 0 == value )
  return 1;

 if ( i_set >= len || value <0)
  return 0;

 int rst = divide_set_v2(set, len, i_set+1, value-set[i_set]) + divide_set_v2(set, len, i_set+1, value);
 /pic/>  return rst;
}

int divide_set_v3( int set[], int len, int** bpHistory, int i_set, int value )
{
 if ( 0 == value )
  return 1;

 if ( i_set >= len || value <0)
  return 0;

 int left = 0;
 int right = 0;
 if ( (value-set[i_set]) >=0 )
 {
  /pic/>   if ( bpHistory[i_set+1][value-set[i_set]] == -1 )
  {
   bpHistory[i_set+1][value-set[i_set]] = divide_set_v3(set, len, bpHistory, i_set+1, value-set[i_set]);
  }
  left = bpHistory[i_set+1][value-set[i_set]];

 }

 if ( value >=0 )
 {
  /pic/>   if ( bpHistory[i_set+1][value] == -1  )
  {
   bpHistory[i_set+1][value] = divide_set_v3(set, len, bpHistory, i_set+1, value);
  }
  right = bpHistory[i_set+1][value];
 }

 return left + right;

}

int divide_set_v4( int set[], int len, std::vector< std::vector<int> > &bpHistory, int i_set, int value )
{
 if ( 0 == value )
  return 1;

 if ( i_set >= len || value <0)
  return 0;

 
 int left = 0;
 int right = 0;
 if ( (value-set[i_set]) >=0 )
 {
  /pic/>   if ( bpHistory[i_set+1][value-set[i_set]] == -1 )
  {
   bpHistory[i_set+1][value-set[i_set]] = divide_set_v4(set, len, bpHistory, i_set+1, value-set[i_set]);
  }
  left = bpHistory[i_set+1][value-set[i_set]];
 
 }

 if ( value >=0 )
 {
  /pic/>   if ( bpHistory[i_set+1][value] == -1  )
  {
   bpHistory[i_set+1][value] = divide_set_v4(set, len, bpHistory, i_set+1, value);
  }
  right = bpHistory[i_set+1][value];
 }

 return left + right;
}

int divide_set_v5( int set[], int len, Bin &bpHistory, int i_set, int value )
{
 if ( 0 == value )
  return 1;

 if ( i_set >= len || value <0)
  return 0;


 int left = 0;
 int right = 0;
 if ( (value-set[i_set]) >=0 )
 {
  /pic/>   /pic/>   int tmp;
  if ( !bpHistory.Find( i_set+1, value-set[i_set], tmp ) )
  {
   tmp = divide_set_v5(set, len, bpHistory, i_set+1, value-set[i_set]);
   bpHistory.Insert( i_set+1, value-set[i_set], tmp );
  }
  left = tmp;

 }

 if ( value >=0 )
 {
  /pic/>   /pic/>   int tmp;
  if ( !bpHistory.Find( i_set+1, value, tmp ) )
  {
   tmp = divide_set_v5(set, len, bpHistory, i_set+1, value);
   bpHistory.Insert( i_set+1, value, tmp );
  }
  right = tmp;
 }

 return left + right;
}

void cal_num( int n )
{
 int* set = new int[n];
 int* label = new int[n];

 /pic/>  int sum_value = 0;
 for ( int i=0; i<n; ++i )
 {
  set[i] = i+1;
  sum_value += set[i];
 }
 memset( label, 0, n*sizeof(int) );

 /pic/>  if( sum_value%2 == 0 )
  divide_set( set, label, n, 0, sum_value/2 );

 delete[] set;
 delete[] label;
}

int cal_num_v2( int n )
{
 int rst = 0;

 int* set = new int[n];

 /pic/>  int sum_value = 0;
 for ( int i=0; i<n; ++i )
 {
  set[i] = i+1;
  sum_value += set[i];
 }

 /pic/>  if( sum_value%2 == 0 )
  rst = divide_set_v2( set, n, 0, sum_value/2 );

 delete[] set;

 return rst;
}

int cal_num_v3( int n )
{
 int rst = 0;

 int* set = new int[n];

 /pic/>  int sum_value = 0;
 for ( int i=0; i<n; ++i )
 {
  set[i] = i+1;
  sum_value += set[i];
 }

 /pic/>  
 if( sum_value%2 == 0 )
 {
  int half_value = sum_value>>1;

  /pic/>   int rows = n+1;
  int cols = half_value+1;
  int** bpHistory = malloc2d<int>(rows, cols, -1);

  bpHistory[0][half_value] = rst = divide_set_v3( set, n, bpHistory, 0, half_value );

  /pic/>   /pic/>   /pic/>   /pic/>   /pic/>   /pic/>   /pic/>   /pic/>   /pic/>   /pic/(float)(rows*cols)<<endl;

  free2d( bpHistory, rows, cols );
 }

 delete[] set;

 return rst;
}

int cal_num_v4( int n )
{
 int rst = 0;

 int* set = new int[n];

 /pic/>  int sum_value = 0;
 for ( int i=0; i<n; ++i )
 {
  set[i] = i+1;
  sum_value += set[i];
 }

 /pic/p>

 if( sum_value%2 == 0 )
 {
  int half_value = sum_value>>1;

  vector<vector<int>> bpHistory( n+1, vector<int>(half_value+1, -1) );

  bpHistory[0][half_value] = rst = divide_set_v4( set, n, bpHistory, 0, half_value );
 }

 delete[] set;

 return rst;
}

int cal_num_v5( int n )
{
 int rst = 0;

 int* set = new int[n];

 /pic/>  int sum_value = 0;
 for ( int i=0; i<n; ++i )
 {
  set[i] = i+1;
  sum_value += set[i];
 }

 /pic/p>

 if( sum_value%2 == 0 )
 {
  int half_value = sum_value>>1;

  int rows = n+1;
  int cols = half_value + 1;
  Bin bin(rows, cols);

  rst = divide_set_v5( set, n, bin, 0, half_value );
 }

 delete[] set;

 return rst;
}

long getSetsNum1(int n)
{
 /pic/>  long sum = 0;
 for (int i = 1; i <= n; ++i) sum += i;
 if ((sum & 1) == 1) return 0;

 sum >>= 1;

 /pic/>  long N = ((n * (n + 1)) >> 1) + 2;
 long* dp = new long[N];
 for (long i = 1; i < N; ++i) dp[i] = 0;

 /pic/>  dp[0] = 1;
 long max = 0;
 for (long i = 1; i <= n; ++i)
 {
  for (long j = max < sum ? max : sum; j >= 0; --j)
   dp[j + i] += dp[j];
  max += i;
 }
 
 /pic/>  /pic/>  /pic/>  return dp[sum] >> 1;
}

void test_cal_num()
{
 FPSController fps;

 int n=104;/pic/pic/pic/pic/pic/pic/pic/p>

 /pic/>  /pic/>  /pic/>  /pic/p>

 /pic/>  /pic/>  /pic/>  /pic/p>

 cout<<endl;
 fps.BeginFrame();
 cout<<cal_num_v3(n)<<endl;
 cout<<"elapse time : "<<fps.GetElapseTime()<<"秒"<<endl;

 cout<<endl;
 fps.BeginFrame();
 cout<<cal_num_v4(n)<<endl;
 cout<<"elapse time : "<<fps.GetElapseTime()<<"秒"<<endl;

 /pic/>  /pic/>  /pic/>  /pic/p>

 cout<<endl;
 fps.BeginFrame();
 cout<<getSetsNum1(n)<<endl;
 cout<<"elapse time : "<<fps.GetElapseTime()<<"秒"<<endl;
  
}

【英語六級(jí)考試流程「」】相關(guān)文章:

2015年英語六級(jí)考試流程03-06

英語六級(jí)口語考試報(bào)名流程12-14

2015大學(xué)英語六級(jí)考試流程03-15

2015年12月英語六級(jí)考試流程03-25

2015年大學(xué)英語六級(jí)考試流程05-16

6月英語六級(jí)考試流程及時(shí)間分配03-21

GMAT考試流程05-09

2016年11月英語六級(jí)口語考試內(nèi)容及流程12-11

2015年6月大學(xué)英語六級(jí)考試流程03-01