Advertisement
a53

Shuffle

a53
Oct 23rd, 2017
136
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.27 KB | None | 0 0
  1. #include <fstream>
  2. using namespace std;
  3. #define NR 11
  4. ifstream f("shuffle.in");
  5. ofstream g("shuffle.out");
  6. int x[NR],a[NR],n,k,i,nrsol=0;
  7.  
  8. int alaturate(int k)
  9. {
  10. for(int i=2;i<=k;++i)
  11. {
  12. for(int j=2;j<=k;++j)
  13. if((x[i-1]==a[j-1]&&x[i]==a[j])||(x[i-1]==a[j]&&x[i]==a[j-1]))
  14. return 1;
  15. }
  16. return 0;
  17. }
  18.  
  19. void init(int k)
  20. {
  21. x[k]=0;
  22. }
  23.  
  24. int succesor(int k)
  25. {
  26. if (x[k]<n)
  27. return 1;
  28. else
  29. return 0;
  30. }
  31.  
  32. int continuare(int k)
  33. {
  34. if(alaturate(k))
  35. return 0;
  36. for(int i=1;i<=k-1;++i)
  37. if(x[k]==x[i])
  38. return 0;
  39. return 1;
  40. }
  41.  
  42. int solutie(int k)
  43. {
  44. if (k==n+1)
  45. return 1;
  46. else
  47. return 0;
  48. }
  49.  
  50. void afisare()
  51. {
  52. ++nrsol;
  53. for(i=1;i<=n;++i)
  54. g<<x[i]<<' ';
  55. g<<'\n';
  56. }
  57.  
  58. void backtracking()
  59. {
  60. int k=1;
  61. init(1);
  62. while(k!=0)
  63. if(solutie(k))
  64. afisare(),--k;
  65. else
  66. if(succesor(k))
  67. {
  68. ++x[k];
  69. if (continuare(k))
  70. ++k;
  71. }
  72. else
  73. init(k),--k;
  74. }
  75.  
  76. int main()
  77. {
  78. f>>n;
  79. for(i=1;i<=n;++i)
  80. f>>a[i];
  81. backtracking();
  82. if(!nrsol)
  83. g<<"nu exista";
  84. return 0;
  85. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement