Implement algorithm in C

You need to implement following two functions in C language:

void preserveTopNValues(double* data, size_t size, size_t n);

void fastPreserveTopNValues(double* data, size_t size, size_t n);

Detailed explanation:

Array "data" contains "size" values which may go in any order (i.e. can be both sorted or unsorted)

and may have duplicates.

Both functions must find top "n" unique absolute values in the "data" and preserve them,

and set other elements of array to zero.

Function "preserveTopNValues" must complete the abovementioned task with minimum additional memory usage,

while may do it slower.

Function "fastrPreserveTopNValues" must complete the abovementioned task with maximum speed,

while may use more additional memory.

Other requirements:

1. Functions must be implemented in plain C (not C++ !!!)

2. Code must conform to C99 standard.

3. Code must be formatted according to Linux astyle and well commented.

4. Code must use "camel case" naming of variables and functions.

5. Code must be compilable without errors on Linux with GCC 4.8.2+ with following compiler options set:

-Wall -Wextra -Werror -std=c99

6. Function can use only standard C library, usage of any 3rd party libraries is strictly not allowed.


1. Source code of functions.

2. Sample program (also delivered as source code) that:

- dispays input data

- calls functions

- dispays output data

- proves that output matches to expected result

- proves that both functions give the same output on the same inputs.

3. GNU Make compatible Makefile to build the sample program.

4. Small plain text file called [url removed, login to view] that shortly explains both algorithms and why they were chosen for the particular variant of implementation (normal/fast).

Habilidades: Algoritmos, Programación en C

Ver más: linked list algorithm in data structure using c, graph library c, c program to implement dijkstra algorithm using priority queues, c programming, algorithm, c algorithm tutorial, c algorithm questions, c algorithm interview questions, c algorithm binary search, binary search in c algorithm, algorithm of prime number in c, algorithm of binary search in c, algorithm for priority queue in c, algorithm for prime numbers in c, algorithm for binary search in c, algorithm and data structure in c, c++ algorithm, C algorithm, algorithm implement btree, algorithm implement matlab

Información del empleador:
( 5 comentarios ) KHARKIV, Ukraine

Nº del proyecto: #11788748

Adjudicado a:



$30 USD en 3 días
(4 comentarios)

10 freelancers están ofertando el promedio de $44 para este trabajo


hi there I would like to do this project if given the opportunity. let me know if you are interested so I can have further details. thanks.

$30 USD en 1 día
(413 comentarios)

I can do

$60 USD en 1 día
(104 comentarios)
$78 USD en 1 día
(6 comentarios)
$30 USD en 1 día
(10 comentarios)
$25 USD en 1 día
(6 comentarios)

We are team of excellent developers and writers. We have 2 year experience related to your project field. We can do your project and solve your all problems according to your requirements. We have read your description Más

$20 USD en 1 día
(2 comentarios)
$25 USD en 1 día
(2 comentarios)

I’d like to be considered for your Implement algorithm in C Project. I'm software engineer with more then 3 years experience in Development & Designing. I'm expert in C, C++, C#, Java, Python, Ruby, Software Develo Más

$25 USD en 0 días
(2 comentarios)

We are highly experienced Post Graduate Engineers, Doctors, IT, ITES, Software, Infrastructure Professionals, Web Designers and IT Architects. We can redo, improve, and publish any engineering, scientific MATLAB, S Más

$150 USD en 1 día
(0 comentarios)

Hi, Thank you very much for posting this project i like to complete your project in a smooth fashion, i like you to check my ability either by directly giving the project or first check my profile an decide. Más

$25 USD en 1 día
(0 comentarios)

My name is Anson, I am a programmer of around 10 years now from the United States, educated at the University of California. My bid is slightly on the higher side, but if you are willing to pay the extra, I promise th Más

$50 USD en 1 día
(0 comentarios)

Hello This is a example code, I can to make a better code #include <stdio.h> void preserveTopNValues(double* data, size_t size, size_t n) { int i; for(i = 0; i < n, ++i) { if(i > size ) { data[i Más

$25 USD en 10 días
(0 comentarios)