当前位置: 首页>>代码示例>>C++>>正文


C++ Sequence::GetBegin方法代码示例

本文整理汇总了C++中Sequence::GetBegin方法的典型用法代码示例。如果您正苦于以下问题:C++ Sequence::GetBegin方法的具体用法?C++ Sequence::GetBegin怎么用?C++ Sequence::GetBegin使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Sequence的用法示例。


在下文中一共展示了Sequence::GetBegin方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: StupidFindDistanceBetweenSequences

int StupidFindDistanceBetweenSequences(const Sequence<iterator>& first_sequence, 
						const Sequence<iterator>& second_sequence) {

    int first_sequence_length = first_sequence.GetLength();
    int second_sequence_length = second_sequence.GetLength();
   
    std::vector< std::vector<int> > answer(first_sequence_length + 1, std::vector<int>(second_sequence_length + 1));

    for (int i = 0; i <= first_sequence_length; ++i) {
        for (int j = 0; j <= second_sequence_length; ++j) {
	    if (i == 0 || j == 0) {
                answer[i][j] = 0;
		continue;
            } 
                
	    if (*(first_sequence.GetBegin() + i - 1) == *(second_sequence.GetBegin() + j - 1)) {
		answer[i][j] = answer[i - 1][ j - 1] + 1;
	    } else {
		answer[i][j] = 0;
		
	    }
	    answer[i][j] = std::max(answer[i - 1][j], std::max(answer[i][j], answer[i][j - 1]));
	         
        } 

    } 
  
    return (second_sequence_length - answer[first_sequence_length][second_sequence_length]) + 
		(first_sequence_length - answer[first_sequence_length][second_sequence_length]);
 }
开发者ID:apronchenkov,项目名称:mipt-oop-399-2,代码行数:30,代码来源:Tests.cpp

示例2: TestOneIterationOfAlgorythm

void TestOneIterationOfAlgorythm(const Sequence<iterator>& first_sequence, 
		const Sequence<iterator>& second_sequence) {

    int first_sequence_length = first_sequence.GetLength();
    int second_sequence_length = second_sequence.GetLength();
    
    Massiv diag_checker(second_sequence_length, first_sequence_length);
    diag_checker[0] = MaxCommonPrefix(first_sequence, second_sequence);

    int distance_between_sequences = FindDistanceBetweenSequences(first_sequence, second_sequence);

    int left_border = std::min(distance_between_sequences, second_sequence_length);
    if (left_border % 2 != distance_between_sequences % 2) left_border--;
    int right_border = std::min(distance_between_sequences, first_sequence_length);
    if (right_border % 2 != distance_between_sequences % 2) right_border--;

    for (int i = 0; i < std::min(second_sequence_length, first_sequence_length); ++i) {
        OneIterationOfAlgorythm(first_sequence, second_sequence, &diag_checker, i);
	for (int diag_number = -left_border; diag_number <= right_border; diag_number += 2) {
	    Sequence<iterator> first_checking_sequence(first_sequence.GetBegin(), 
			first_sequence.GetBegin() + diag_checker[diag_number]);
	    Sequence<iterator> second_checking_sequence(second_sequence.GetBegin(), 
			second_sequence.GetBegin() + diag_checker[diag_number] - diag_number);
	    
	    if (StupidFindDistanceBetweenSequences(first_checking_sequence, second_checking_sequence) != i)
		throw std::logic_error("TestOneIterationOfAlgorythm : FAIL");
	}
    }
}
开发者ID:apronchenkov,项目名称:mipt-oop-399-2,代码行数:29,代码来源:Tests.cpp

示例3: TestFindOverlapPoint

void TestFindOverlapPoint(const Sequence<iterator>& first_sequence, 
		const Sequence<iterator>& second_sequence) {

    
    int distance_between_sequences = FindDistanceBetweenSequences(first_sequence, second_sequence);

    iterator first_begin = first_sequence.GetBegin();
    iterator second_begin = second_sequence.GetBegin();
    iterator first_end = first_sequence.GetEnd();
    iterator second_end = second_sequence.GetEnd();
    
    Point point = FindOverlapPoint(distance_between_sequences, first_sequence, second_sequence);

    Sequence<iterator> left_first_sequence(first_begin, first_begin + point.x_); 
    Sequence<iterator> left_second_sequence(second_begin, second_begin + point.y_);

    Sequence<iterator> right_first_sequence(first_begin + point.x_, first_end); 
    Sequence<iterator> right_second_sequence(second_begin + point.y_, second_end);
    
    int distance_left = FindDistanceBetweenSequences(left_first_sequence, left_second_sequence);
    
    int distance_right = FindDistanceBetweenSequences(right_first_sequence, right_second_sequence);
    
    int distance_full = FindDistanceBetweenSequences(first_sequence, second_sequence);
    
    if ( !(distance_full == distance_left + distance_right && distance_left - distance_right <= 1 
            && distance_left - distance_right >= -1) ) 
        throw std::logic_error("TestFindOverlapPoint: FAIL");
    
}
开发者ID:apronchenkov,项目名称:mipt-oop-399-2,代码行数:30,代码来源:Tests.cpp


注:本文中的Sequence::GetBegin方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。