C++ 运行 算法时间
C++ Running Time of Algorithms
我已经将 Naive Approach/Finite Automata 搜索算法作为作业。教授还要求我们打印每个算法的运行时间。我试过;
int start_s=clock();
// the code you wish to time goes here
int stop_s=clock();
cout << "time: " << (stop_s-start_s)/double(CLOCKS_PER_SEC)*1000 << endl;
这些东西但是它不能在 main 之外计算...我想。
这是我的代码;
#include <iostream>
#include <sstream>
#include <fstream>
#include<stdio.h>
#include<string.h>
#include <ctime>
#define NO_OF_CHARS 256
using namespace std;
//Naive Approach search starts here:
void naive_search(string pat, string txt)
{
int M = pat.length();
int N = txt.length();
/* A loop to slide pat[] one by one */
for (int i = 0; i <= N - M; i++)
{
int j;
/* For current index i, check for pattern match */
for (j = 0; j < M; j++)
{
if (txt[i + j] != pat[j])
break;
}
if (j == M) // if pat[0...M-1] = txt[i, i+1, ...i+M-1]
{
printf("Found pattern at index: %d \n", i);
}
}
}
//Finite Autoama starts here:
int goNextState(string pattern, int num_total_state, int state, int given_character) {
// If our character match with the pattern
if (state < num_total_state && given_character == pattern[state])
return state + 1;
int nextstate, index;
//If dont match, search the maximum legth of matched pattern
// For example pattern is = aabb and our index is aabc , start to match first character of pattern and last character of given index increasingly and decreasingly..
for (nextstate = state; nextstate > 0; nextstate--)
{
if (pattern[nextstate - 1] == given_character) // start to find longest matched substring
{
for (index = 0; index < nextstate - 1; index++) {
if (pattern[index] != pattern[state - nextstate + 1 + index])
break;
}
if (index == nextstate - 1)
return nextstate;
}
}
return 0;
}
void Transition_Table(string pattern, int lengt_of_pattern, int Table_Array[][NO_OF_CHARS])
{
int given_character;
int state;
for (state = 0; state <= lengt_of_pattern; state++)
for (given_character = 0; given_character<NO_OF_CHARS; ++given_character)
Table_Array[state][given_character] = goNextState(pattern, lengt_of_pattern, state, given_character);
}
void Automata_Compute(string pattern, string given_text) {
int numberOfLine = 0;
int count = 0;
int A = pattern.length();
int B = given_text.length();
int Table_Array[1000][NO_OF_CHARS];
Transition_Table(pattern, A, Table_Array);
int i, state = 0;
for (i = 0; i<B; i++) {
// get input ...
state = Table_Array[state][given_text[i]];
if (state == A) {
count++;
printf("Found pattern at index: %d \n",i - A + 1);
}
}
}
// Driver program to test above function
int main()
{
ifstream ifile("Text.txt"); // open
string text(istreambuf_iterator<char>(ifile), {});
string pat = ("AABA");
//string text = ("AABABBABABAAABABBABAAABABBBBBBBAAAAAAABBAABA\nABABABAAABAAAABBBBBAABA\nABABABAABABBBBAAAAABA");
cout << "Naive Approach:" << endl;
naive_search(pat, text);
cout << "\nFinite Automata:" << endl;
Automata_Compute(pat, text);
return 0;
}
编辑:我需要有关如何计算 Naive Approach Search Algorithm 和 Finite Autoamata Search Algorithm 时间的帮助。
这个问题还不是很清楚,但是是什么阻止了你这样做:
std::clock_t start = std::clock();
method_to_time();
std::clock_t end = std::clock();
std::cout << "Time taken to compute method_to_time() = "
<< static_cast<double)((end-start))/CLOCKS_PER_SEC << " seconds.";
请注意,如上所述使用 <ctime>
并不是准确计时算法的最佳方式,因为时钟根据处理器周期运行,因此可以根据它是处于高负载还是低负载给出不同的结果。但是,如果准确性不是大问题,那么上面是 "fine".
要获得更好的计时工具,请查看 <chrono>
header。
@ArchbishopOfBanterbury 感谢您的帮助!我按照你的建议做了,并且成功了;
int main()
{
ifstream ifile("Example.txt"); // open
string text(istreambuf_iterator<char>(ifile), {});
string pat = ("nut");
//string text = ("AABABBABABAAABABBABAAABABBBBBBBAAAAAAABBAABA\nABABABAAABAAAABBBBBAABA\nABABABAABABBBBAAAAABA");
cout << "Naive Approach:" << endl;
high_resolution_clock::time_point t1 = high_resolution_clock::now();
naive_search(pat, text);
high_resolution_clock::time_point t2 = high_resolution_clock::now();
auto nduration = duration_cast<microseconds>(t2 - t1).count();
cout << "\nFinite Automata:" << endl;
high_resolution_clock::time_point t3 = high_resolution_clock::now();
Automata_Compute(pat, text);
high_resolution_clock::time_point t4 = high_resolution_clock::now();
auto fduration = duration_cast<microseconds>(t4 - t3).count();
cout << "\nNaive Approach Duration: ";
cout << nduration;
cout << "\nFinite Automata Duration: ";
cout << fduration << endl;
cout << "\n";
return 0;
}
我已经将 Naive Approach/Finite Automata 搜索算法作为作业。教授还要求我们打印每个算法的运行时间。我试过;
int start_s=clock();
// the code you wish to time goes here
int stop_s=clock();
cout << "time: " << (stop_s-start_s)/double(CLOCKS_PER_SEC)*1000 << endl;
这些东西但是它不能在 main 之外计算...我想。 这是我的代码;
#include <iostream>
#include <sstream>
#include <fstream>
#include<stdio.h>
#include<string.h>
#include <ctime>
#define NO_OF_CHARS 256
using namespace std;
//Naive Approach search starts here:
void naive_search(string pat, string txt)
{
int M = pat.length();
int N = txt.length();
/* A loop to slide pat[] one by one */
for (int i = 0; i <= N - M; i++)
{
int j;
/* For current index i, check for pattern match */
for (j = 0; j < M; j++)
{
if (txt[i + j] != pat[j])
break;
}
if (j == M) // if pat[0...M-1] = txt[i, i+1, ...i+M-1]
{
printf("Found pattern at index: %d \n", i);
}
}
}
//Finite Autoama starts here:
int goNextState(string pattern, int num_total_state, int state, int given_character) {
// If our character match with the pattern
if (state < num_total_state && given_character == pattern[state])
return state + 1;
int nextstate, index;
//If dont match, search the maximum legth of matched pattern
// For example pattern is = aabb and our index is aabc , start to match first character of pattern and last character of given index increasingly and decreasingly..
for (nextstate = state; nextstate > 0; nextstate--)
{
if (pattern[nextstate - 1] == given_character) // start to find longest matched substring
{
for (index = 0; index < nextstate - 1; index++) {
if (pattern[index] != pattern[state - nextstate + 1 + index])
break;
}
if (index == nextstate - 1)
return nextstate;
}
}
return 0;
}
void Transition_Table(string pattern, int lengt_of_pattern, int Table_Array[][NO_OF_CHARS])
{
int given_character;
int state;
for (state = 0; state <= lengt_of_pattern; state++)
for (given_character = 0; given_character<NO_OF_CHARS; ++given_character)
Table_Array[state][given_character] = goNextState(pattern, lengt_of_pattern, state, given_character);
}
void Automata_Compute(string pattern, string given_text) {
int numberOfLine = 0;
int count = 0;
int A = pattern.length();
int B = given_text.length();
int Table_Array[1000][NO_OF_CHARS];
Transition_Table(pattern, A, Table_Array);
int i, state = 0;
for (i = 0; i<B; i++) {
// get input ...
state = Table_Array[state][given_text[i]];
if (state == A) {
count++;
printf("Found pattern at index: %d \n",i - A + 1);
}
}
}
// Driver program to test above function
int main()
{
ifstream ifile("Text.txt"); // open
string text(istreambuf_iterator<char>(ifile), {});
string pat = ("AABA");
//string text = ("AABABBABABAAABABBABAAABABBBBBBBAAAAAAABBAABA\nABABABAAABAAAABBBBBAABA\nABABABAABABBBBAAAAABA");
cout << "Naive Approach:" << endl;
naive_search(pat, text);
cout << "\nFinite Automata:" << endl;
Automata_Compute(pat, text);
return 0;
}
编辑:我需要有关如何计算 Naive Approach Search Algorithm 和 Finite Autoamata Search Algorithm 时间的帮助。
这个问题还不是很清楚,但是是什么阻止了你这样做:
std::clock_t start = std::clock();
method_to_time();
std::clock_t end = std::clock();
std::cout << "Time taken to compute method_to_time() = "
<< static_cast<double)((end-start))/CLOCKS_PER_SEC << " seconds.";
请注意,如上所述使用 <ctime>
并不是准确计时算法的最佳方式,因为时钟根据处理器周期运行,因此可以根据它是处于高负载还是低负载给出不同的结果。但是,如果准确性不是大问题,那么上面是 "fine".
要获得更好的计时工具,请查看 <chrono>
header。
@ArchbishopOfBanterbury 感谢您的帮助!我按照你的建议做了,并且成功了;
int main()
{
ifstream ifile("Example.txt"); // open
string text(istreambuf_iterator<char>(ifile), {});
string pat = ("nut");
//string text = ("AABABBABABAAABABBABAAABABBBBBBBAAAAAAABBAABA\nABABABAAABAAAABBBBBAABA\nABABABAABABBBBAAAAABA");
cout << "Naive Approach:" << endl;
high_resolution_clock::time_point t1 = high_resolution_clock::now();
naive_search(pat, text);
high_resolution_clock::time_point t2 = high_resolution_clock::now();
auto nduration = duration_cast<microseconds>(t2 - t1).count();
cout << "\nFinite Automata:" << endl;
high_resolution_clock::time_point t3 = high_resolution_clock::now();
Automata_Compute(pat, text);
high_resolution_clock::time_point t4 = high_resolution_clock::now();
auto fduration = duration_cast<microseconds>(t4 - t3).count();
cout << "\nNaive Approach Duration: ";
cout << nduration;
cout << "\nFinite Automata Duration: ";
cout << fduration << endl;
cout << "\n";
return 0;
}