Ordenar una array usando la programación de socket en C

Dada una array de enteros positivos sin ordenar, ordene la array dada usando la programación de Socket . Ejemplos:

Input : 4 5 6 1 8 2 7 9 3 0 
Output :0 1 2 3 4 5 6 7 8 9

Input : 9 8 1 4 0
Output : 0 1 4 8 9

Compile estos archivos usando el comando gcc (gcc client.c -o client y gcc server.c -o server). Ejecute el programa usando ./servidor y ./cliente (Nota: primero debe ejecutar el programa del servidor que esperará la respuesta del cliente y luego el código del cliente). 

En este programa, el cliente tomará la entrada y la enviará al servidor y el servidor clasificará la array utilizando la clasificación de burbujas. 

C

// Client code in C to sort the array
#include <arpa/inet.h>
#include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <unistd.h>
 
// Driver code
int main(int argc, char* argv[])
{
    int sock;
    struct sockaddr_in server;
    int server_reply[10];
    int number[10] = { 5, 4, 3, 8, 9, 1, 2, 0, 6 }, i, temp;
 
    // Create socket
    sock = socket(AF_INET, SOCK_STREAM, 0);
    if (sock == -1) {
        printf("Could not create socket");
    }
    puts("Socket created");
 
    server.sin_addr.s_addr = inet_addr("127.0.0.1");
    server.sin_family = AF_INET;
    server.sin_port = htons(8880);
 
    // Connect to remote server
    if (connect(sock, (struct sockaddr*)&server, sizeof(server)) < 0) {
        perror("connect failed. Error");
        return 1;
    }
 
    puts("Connected\n");
 
    if (send(sock, &number, 10 * sizeof(int), 0) < 0) {
        puts("Send failed");
        return 1;
    }
 
    // Receive a reply from the server
    if (recv(sock, &server_reply, 10 * sizeof(int), 0) < 0) {
        puts("recv failed");
        return 0;
    }
 
    puts("Server reply :\n");
    for (i = 0; i < 10; i++) {
        printf("%d\n", server_reply[i]);
    }
 
    // close the socket
    close(sock);
    return 0;
}

Nota: Guarde el archivo anterior como client.c 

C

// Server code in C to sort the array
#include <arpa/inet.h>
#include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <unistd.h>
 
void bubble_sort(int[], int);
 
// Driver code
int main(int argc, char* argv[])
{
    int socket_desc, client_sock, c, read_size;
    struct sockaddr_in server, client;
    int message[10], i;
 
    // Create socket
    socket_desc = socket(AF_INET, SOCK_STREAM, 0);
    if (socket_desc == -1) {
        printf("Could not create socket");
    }
    puts("Socket created");
 
    // Prepare the sockaddr_in structure
    server.sin_family = AF_INET;
    server.sin_addr.s_addr = INADDR_ANY;
    server.sin_port = htons(8880);
 
    // Bind the socket
    if (bind(socket_desc, (struct sockaddr*)&server, sizeof(server)) < 0) {
 
        // print the error message
        perror("bind failed. Error");
        return 1;
    }
    puts("bind done");
 
    // listen to the socket
    listen(socket_desc, 3);
 
    puts("Waiting for incoming connections...");
    c = sizeof(struct sockaddr_in);
 
    // accept connection from an incoming client
    client_sock = accept(socket_desc, (struct sockaddr*)&client, (socklen_t*)&c);
 
    if (client_sock < 0) {
        perror("accept failed");
        return 1;
    }
 
    puts("Connection accepted");
 
    // Receive a message from client
    while ((read_size = recv(client_sock, &message, 10 * sizeof(int), 0)) > 0) {
 
        bubble_sort(message, 10);
 
        write(client_sock, &message, 10 * sizeof(int));
    }
 
    if (read_size == 0) {
        puts("Client disconnected");
    }
    else if (read_size == -1) {
        perror("recv failed");
    }
 
    return 0;
}
 
// Function to sort the array
void bubble_sort(int list[], int n)
{
    int c, d, t;
 
    for (c = 0; c < (n - 1); c++) {
        for (d = 0; d < n - c - 1; d++) {
            if (list[d] > list[d + 1]) {
 
                /* Swapping */
                t = list[d];
                list[d] = list[d + 1];
                list[d + 1] = t;
            }
        }
    }
}

Nota: Guarde el archivo anterior como server.c Salida:

0 1 2 3 4 5 6 7 8 9 

Publicación traducida automáticamente

Artículo escrito por ajay0007 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *