Advertisement
Guest User

Untitled

a guest
Jun 18th, 2018
99
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.83 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4.  
  5. typedef struct
  6. {
  7. char name[20];
  8. int grades[10];
  9. int hianyzasok;
  10. }element;
  11.  
  12.  
  13. int rendez(element *a, element *b){
  14. //ki is lehet kényszeríteni void*ból
  15. int i, j, sum1, sum2;
  16.  
  17. for(i = sum1 = sum2 = 0; i < 10; i++){
  18. if(a->grades[i] == 0)
  19. sum1++;
  20. if(b->grades[i] == 0)
  21. sum2++;
  22. }
  23.  
  24. a->hianyzasok = sum1;
  25. b->hianyzasok = sum2;
  26.  
  27. if(sum1 > sum2)
  28. return 1;
  29. if(sum1 < sum2)
  30. return -1;
  31.  
  32. return strcmp(a->name, b->name);
  33.  
  34.  
  35. }
  36.  
  37. int main(int argc, char **argv)
  38. {
  39. FILE *fp = fopen(argv[1], "rb"); // +b
  40. int i,j,k,l, in = atoi(argv[2]);
  41.  
  42.  
  43. //Dinamikus beolvasás
  44. int tsize = 5; //tömb eredeti mérete
  45. element *t = malloc(tsize * sizeof(element)); //helyek lefoglalása
  46. element be;
  47. for(l = 0; fread( &be, sizeof(element) - sizeof(int) , 1, fp) != 0; l++){
  48. // -sizeof int a hiányzások tárolása miatt
  49.  
  50. //ha túlindexelnénk a tömböt, akkor növeljük a méretet, létrehozunk egy új tömböt, átmásoljuk az adatokat, és kicseréljük a mutatót az újra
  51. if(l >= tsize){
  52. tsize += 10;
  53. element *csere = malloc(tsize * sizeof(element));
  54. memcpy(csere, t, l * sizeof(element));
  55. free(t);
  56. t = csere;
  57. }
  58. t[l] = be;
  59. }
  60. //Dinamikus beolvasás
  61.  
  62.  
  63. printf("%d\n", l);
  64. //darabszám kiírása
  65.  
  66. //innentõl kezdve rendesen lehet használni az adatokat
  67.  
  68. qsort(t, l, sizeof(element), rendez);
  69.  
  70. for(i = 0; i < l; i++){
  71. printf("%s (%d):", t[i].name, t[i].hianyzasok);
  72.  
  73. for(j = 0; j < 10; j++)
  74. printf(" %d", t[i].grades[j]);
  75.  
  76. puts("");
  77. }
  78. return 0;
  79. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement