Quoted from wikipedia, the P vs NP problem, regarding the time complexity of algorithms “… asks whether every problem whose solution can be quickly verified by a computer can also be quickly solved by a computer.”
I am hoping that somebody can clarify what the difference between “verifying the problem” and “solving the problem” is here.
It’s not "verifying the problem", but "verifying the solution". For example you can check in polynomial time whether a given set is valid for SAT. The actual generation of such set is NP hard. The section Verifier-based definition in the Wikipedia article NP (complexity) could help you a little bit:
If you’re more into graph theory the Hamilton cycle is a NP-complete problem. It’s trivial to check whether a given solution is a Hamilton cycle (linear complexity, traverse the solution path), but if P != NP than there exists no algorithm with polynomial runtime which solves the problem.
Maybe the term "quick" is misleading in this context. An algorithm is quick in this regard if and only if it’s worst-case runtime is bounded by a polynomial function, such as
O(n)orO(n log n). The creation of all permutations for a given range with the lengthnis not bounded, as you haven!different permutations. This means that the problem could be solved in n 100 log n, which will take a very long time, but this is still considered fast. On the other hand, one of the first algorithms for TSP was O(n!) and another one was O(n2 2n). And compared to polynomial functions these things grow really, really fast.