SashkoKlincharov

[Java][АПС] - Спој листи наизменично

Jan 23rd, 2020
70
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 7.27 KB | None | 0 0
  1. Спој листи наизменично Problem 3 (1 / 9)
  2. Дадени се две еднострано поврзани листи чии што јазли содржат по еден природен број. Треба да се спојат двете листи во една резултантна на тој начин што наизменично прво ќе се додаваат првите два јазли од првата листа во резултантната, па првите два од втората листа, па следните два од првата, па следните два од втората итн. Јазлите што ќе останат треба да се додадат на крај во резултантната листа, прво оние што останале од првата листа, потоа оние што останале од втората листа.
  3.  
  4. Во првиот ред од влезот се дадени броевите од кои се составени јазлите по редослед во првата листа, а во вториот ред броевите од кои се составени јазлите по редослед во втората листа. На излез треба да се испечатат јазлите по редослед во резултантната споена листа.
  5.  
  6. Забелешка: Да се креира податочна структура еднострано поврзана листа и истата да се искористи во задачата.
  7.  
  8. Sample input
  9. 4
  10. 1 2 3 4
  11. 3
  12. 5 6 7
  13.  
  14. Sample output
  15. 1 2 5 6 3 4 7
  16.  
  17.  
  18.  
  19. import java.util.Scanner;
  20. import java.util.Iterator;
  21. import java.util.NoSuchElementException;
  22.  
  23. class SLL<E> {
  24. private SLLNode<E> first;
  25.  
  26. public SLL() {
  27. // Construct an empty SLL
  28. this.first = null;
  29. }
  30.  
  31. public void deleteList() {
  32. first = null;
  33. }
  34.  
  35. public int length() {
  36. int ret;
  37. if (first != null) {
  38. SLLNode<E> tmp = first;
  39. ret = 1;
  40. while (tmp.succ != null) {
  41. tmp = tmp.succ;
  42. ret++;
  43. }
  44. return ret;
  45. } else
  46. return 0;
  47.  
  48. }
  49.  
  50. @Override
  51. public String toString() {
  52. String ret = new String();
  53. if (first != null) {
  54. SLLNode<E> tmp = first;
  55. ret += tmp + "->";
  56. while (tmp.succ != null) {
  57. tmp = tmp.succ;
  58. ret += tmp + "->";
  59. }
  60. } else
  61. ret = "Prazna lista!!!";
  62. return ret;
  63. }
  64.  
  65. public void insertFirst(E o) {
  66. SLLNode<E> ins = new SLLNode<E>(o, first);
  67. first = ins;
  68. }
  69.  
  70. public void insertAfter(E o, SLLNode<E> node) {
  71. if (node != null) {
  72. SLLNode<E> ins = new SLLNode<E>(o, node.succ);
  73. node.succ = ins;
  74. } else {
  75. System.out.println("Dadenot jazol e null");
  76. }
  77. }
  78.  
  79. public void insertBefore(E o, SLLNode<E> before) {
  80.  
  81. if (first != null) {
  82. SLLNode<E> tmp = first;
  83. if(first==before){
  84. this.insertFirst(o);
  85. return;
  86. }
  87. //ako first!=before
  88. while (tmp.succ != before)
  89. tmp = tmp.succ;
  90. if (tmp.succ == before) {
  91. SLLNode<E> ins = new SLLNode<E>(o, before);
  92. tmp.succ = ins;
  93. } else {
  94. System.out.println("Elementot ne postoi vo listata");
  95. }
  96. } else {
  97. System.out.println("Listata e prazna");
  98. }
  99. }
  100.  
  101. public void insertLast(E o) {
  102. if (first != null) {
  103. SLLNode<E> tmp = first;
  104. while (tmp.succ != null)
  105. tmp = tmp.succ;
  106. SLLNode<E> ins = new SLLNode<E>(o, null);
  107. tmp.succ = ins;
  108. } else {
  109. insertFirst(o);
  110. }
  111. }
  112.  
  113. public E deleteFirst() {
  114. if (first != null) {
  115. SLLNode<E> tmp = first;
  116. first = first.succ;
  117. return tmp.element;
  118. } else {
  119. System.out.println("Listata e prazna");
  120. return null;
  121. }
  122. }
  123.  
  124. public E delete(SLLNode<E> node) {
  125. if (first != null) {
  126. SLLNode<E> tmp = first;
  127. if(first ==node){
  128. return this.deleteFirst();
  129. }
  130. while (tmp.succ != node && tmp.succ.succ != null)
  131. tmp = tmp.succ;
  132. if (tmp.succ == node) {
  133. tmp.succ = tmp.succ.succ;
  134. return node.element;
  135. } else {
  136. System.out.println("Elementot ne postoi vo listata");
  137. return null;
  138. }
  139. } else {
  140. System.out.println("Listata e prazna");
  141. return null;
  142. }
  143.  
  144. }
  145.  
  146. public SLLNode<E> getFirst() {
  147. return first;
  148. }
  149.  
  150. public SLLNode<E> find(E o) {
  151. if (first != null) {
  152. SLLNode<E> tmp = first;
  153. while (tmp.element != o && tmp.succ != null)
  154. tmp = tmp.succ;
  155. if (tmp.element == o) {
  156. return tmp;
  157. } else {
  158. System.out.println("Elementot ne postoi vo listata");
  159. }
  160. } else {
  161. System.out.println("Listata e prazna");
  162. }
  163. return first;
  164. }
  165.  
  166. public Iterator<E> iterator () {
  167. // Return an iterator that visits all elements of this list, in left-to-right order.
  168. return new LRIterator<E>();
  169. }
  170.  
  171. // //////////Inner class ////////////
  172.  
  173. private class LRIterator<E> implements Iterator<E> {
  174.  
  175. private SLLNode<E> place, curr;
  176.  
  177. private LRIterator() {
  178. place = (SLLNode<E>) first;
  179. curr = null;
  180. }
  181.  
  182. public boolean hasNext() {
  183. return (place != null);
  184. }
  185.  
  186. public E next() {
  187. if (place == null)
  188. throw new NoSuchElementException();
  189. E nextElem = place.element;
  190. curr = place;
  191. place = place.succ;
  192. return nextElem;
  193. }
  194.  
  195. public void remove() {
  196. //Not implemented
  197. }
  198. }
  199.  
  200. public void mirror(){
  201. if (first != null) {
  202. //m=nextsucc, p=tmp,q=next
  203. SLLNode<E> tmp = first;
  204. SLLNode<E> newsucc = null;
  205. SLLNode<E> next;
  206.  
  207. while(tmp != null){
  208. next = tmp.succ;
  209. tmp.succ = newsucc;
  210. newsucc = tmp;
  211. tmp = next;
  212. }
  213. first = newsucc;
  214. }
  215.  
  216. }
  217.  
  218. public void merge (SLL<E> in){
  219. if (first != null) {
  220. SLLNode<E> tmp = first;
  221. while(tmp.succ != null)
  222. tmp = tmp.succ;
  223. tmp.succ = in.getFirst();
  224. }
  225. else{
  226. first = in.getFirst();
  227. }
  228. }
  229. }
  230.  
  231. class SLLNode<E> {
  232. protected E element;
  233. protected SLLNode<E> succ;
  234.  
  235. public SLLNode(E elem, SLLNode<E> succ) {
  236. this.element = elem;
  237. this.succ = succ;
  238. }
  239.  
  240. @Override
  241. public String toString() {
  242. return element.toString();
  243. }
  244. }
  245.  
  246. public class SpecialSLLJoin {
  247. public static SLL<Integer> specialJoin(SLL<Integer> lista1,SLL<Integer> lista2){
  248. SLL<Integer> result = new SLL<Integer>();
  249. SLLNode<Integer> tmp = lista1.getFirst();
  250. SLLNode<Integer> tmp2 = lista2.getFirst();
  251. int brojac = 1,brojac2 = 1;
  252. while(tmp!=null) {
  253. result.insertLast(tmp.element);
  254. if(brojac==2) {
  255. while(tmp2!=null) {
  256. //System.out.println(tmp2.element);
  257. result.insertLast(tmp2.element);
  258. if(brojac2==2) {
  259. brojac2 = 1;
  260. brojac = 0;
  261. tmp2 = tmp2.succ;
  262. break;
  263. }
  264. tmp2 = tmp2.succ;
  265. brojac2++;
  266. }
  267. }
  268. brojac++;
  269. tmp = tmp.succ;
  270. }
  271. while(tmp!=null) {
  272. result.insertLast(tmp.element);
  273. tmp = tmp.succ;
  274. }
  275. while(tmp2!=null) {
  276. result.insertLast(tmp2.element);
  277. tmp2 = tmp2.succ;
  278. }
  279.  
  280. return result;
  281. }
  282. public static void main(String[] args) {
  283. Scanner input = new Scanner(System.in);
  284. int n = input.nextInt();
  285. SLL<Integer> lista1 = new SLL<Integer>();
  286. for(int i=0;i<n;i++) {
  287. lista1.insertLast(input.nextInt());
  288. }
  289. int m = input.nextInt();
  290. SLL<Integer> lista2 = new SLL<Integer>();
  291. for(int i=0;i<m;i++) {
  292. lista2.insertLast(input.nextInt());
  293. }
  294. System.out.println(specialJoin(lista1,lista2));
  295. }
  296.  
  297. }
Add Comment
Please, Sign In to add comment