C Πρόγραμμα ανταλλαγής αριθμών σε κυκλική σειρά χρησιμοποιώντας κλήση με αναφορά

Σε αυτό το παράδειγμα, οι τρεις αριθμοί που εισάγει ο χρήστης ανταλλάσσονται με κυκλική σειρά χρησιμοποιώντας κλήση με αναφορά.

Για να κατανοήσετε αυτό το παράδειγμα, θα πρέπει να γνωρίζετε τις ακόλουθες θεματολογίες προγραμματισμού Γ:

  • C Δείκτες
  • C Pass Διευθύνσεις και δείκτες

Πρόγραμμα ανταλλαγής στοιχείων με χρήση κλήσης με αναφορά

#include void cyclicSwap(int *a, int *b, int *c); int main() ( int a, b, c; printf("Enter a, b and c respectively: "); scanf("%d %d %d", &a, &b, &c); printf("Value before swapping:"); printf("a = %d b = %d c = %d", a, b, c); cyclicSwap(&a, &b, &c); printf("Value after swapping:"); printf("a = %d b = %d c = %d", a, b, c); return 0; ) void cyclicSwap(int *n1, int *n2, int *n3) ( int temp; // swapping in cyclic order temp = *n2; *n2 = *n1; *n1 = *n3; *n3 = temp; ) 

Παραγωγή

Εισαγάγετε a, b και c αντίστοιχα: 1 2 3 Τιμή πριν από την ανταλλαγή: a = 1 b = 2 c = 3 Τιμή μετά την ανταλλαγή: a = 3 b = 1 c = 2 

Εδώ, οι τρεις αριθμοί που εισάγει ο χρήστης αποθηκεύονται σε μεταβλητές a, b και c αντίστοιχα. Οι διευθύνσεις αυτών των αριθμών μεταβιβάζονται στη cyclicSwap()συνάρτηση.

cyclicSwap(&a, &b, &c); 

Στον ορισμό της συνάρτησης cyclicSwap(), έχουμε εκχωρήσει αυτές τις διευθύνσεις σε δείκτες.

cyclicSwap(int *n1, int *n2, int *n3) (… ) 

Όταν cyclicSwap()αλλάζουν τα n1, n2 και n3 , αλλάζουν επίσης οι τιμές των a, b και c στο εσωτερικό main().

Σημείωση: Η cyclicSwap()λειτουργία δεν επιστρέφει τίποτα.

ενδιαφέροντα άρθρα...