Advertisement
Guest User

Untitled

a guest
Jan 21st, 2018
89
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.72 KB | None | 0 0
  1. char * sb(char *a, char *b, short n, char *res)
  2. {
  3. if (!((n > 1 && n < 11) || n == 16))
  4. {
  5. printf("Invalid numeric system\n");
  6. return NULL;
  7. }
  8. if (a[0] == '0')
  9. {
  10. printf("Invalid a[0]!=0\n");
  11. return NULL;
  12. }
  13. //struct operation op;
  14. //buildoperation(a, b, n, res, &op, SUB);
  15. long alen = 0 - (a - strchr(a, '\0'));
  16. long blen = 0 - (b - strchr(b, '\0'));
  17. if (alen < blen)
  18. {
  19. printf("Invalid a>=b\n");
  20. return NULL;
  21. }
  22. else if (alen == blen)
  23. {
  24. for (long l = 0; l < alen; l++)
  25. {
  26. if (a[l] == b[l])
  27. {
  28. if (l == alen - 1)
  29. {
  30. res = "0\0";
  31. return res;
  32. }
  33. continue;
  34. }
  35. else if (a[l] > b[l])
  36. {
  37. break;
  38. }
  39. else
  40. {
  41. printf("Invalid a>=b\n");
  42. return NULL;
  43. }
  44. }
  45. }
  46. res[alen] = '\0';
  47. alen -= 1;
  48. blen -= 1;
  49. short m = 0;
  50. for ( ; alen >= 0; alen--, blen--)
  51. {
  52. short aa = (a[alen] >= '0' && a[alen] <= '9') ? (a[alen] - '0') : (a[alen] - 'A' + 10);
  53. short bb =
  54. (blen >= 0 ?
  55. ((b[blen] >= '0' && b[blen] <= '9') ? (b[blen] - '0') : (b[blen] - 'A' + 10))
  56. : 0);
  57. if (m == 1)
  58. {
  59. if (aa == 0)
  60. {
  61. a[alen] = (n < 11) ? ('0' + n - 1) : ('A' + n - 10 - 1);
  62. }
  63. else
  64. {
  65. a[alen] =
  66. (n < 11) ?
  67. (a[alen] - 1)
  68. : ((a[alen] == 'A') ? '9' : (a[alen] - 1));
  69. m = 0;
  70. }
  71. }
  72. if (aa >= bb)
  73. {
  74. aa = aa - bb;
  75. }
  76. else
  77. {
  78. m = 1;
  79. aa = (n < 11) ? (n + aa) : (10 + aa);
  80. aa = aa - bb;
  81. }
  82. res[alen] = (aa < 10) ? ('0' + aa) : ('A' + aa - 10);
  83. }/*
  84. if (res[0] == '0')
  85. {
  86. alen = 0 - (res - strchr(res, '\0'));
  87. long l = 0;
  88. while (res[l] == '0')
  89. {
  90. l++;
  91. }
  92. for (long ll = 0; ll < alen; ll++)
  93. {
  94. res[ll] = res[ll + l];
  95. }
  96. }*/
  97. return res;
  98. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement