Advertisement
Alx09

Ex2

Jun 1st, 2020
778
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 1.02 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. #define natural unsigned short
  5. #define maxN 10000
  6. unsigned v[maxN], n;
  7. static char st[] = { 0, 'A', 'G', 'V'};
  8.  
  9. void Init(natural k) {
  10.     v[k] = 0;
  11. }
  12. natural Succesor(natural k) {
  13.     if (v[k] < 3) {
  14.         v[k]++;
  15.         return 1;
  16.     }
  17.     return 0;
  18. }
  19.  
  20. natural Valid(natural k) {
  21.     return 1;
  22. }
  23.  
  24. natural Solution(natural k) {
  25.     return (k == n);
  26. }
  27.  
  28. void Print() {
  29.     natural i;
  30.  
  31.     for (i = 1; i <= n; i++)
  32.         printf("R%c", st[v[i]]);
  33.     printf("\n");
  34.     for (i = 1; i <= n; i++)
  35.         printf("%cR", st[v[i]]);
  36.     printf("\n");
  37. }
  38.  
  39. void Back() {
  40.     natural k = 1, isS, isV;
  41.     Init(k);
  42.     while (k > 0) {
  43.         isS = 0; isV = 0;
  44.         if (k <= n)
  45.             do {
  46.                 isS = Succesor(k);
  47.                 if (isS) isV = Valid(k);
  48.             } while (isS && !isV);
  49.             if (isS)
  50.                 if (Solution(k))
  51.                     Print();
  52.                 else {
  53.                     k++;
  54.                     Init(k);
  55.                 }
  56.             else
  57.                 k--;
  58.     }
  59. }
  60.  
  61. int main() {
  62.     do {
  63.         system("cls");
  64.         printf("n = "); scanf("%d", &n);
  65.     } while (n >= maxN );
  66.     n /= 2;
  67.     Back();
  68.     system("pause");
  69.     return 0;
  70.  
  71. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement