Test2
This commit is contained in:
parent
a979740974
commit
44556f410c
76
nulleins.c
76
nulleins.c
@ -1,19 +1,4 @@
|
|||||||
//Programm soll zufällig 0,1 mit x beliebigen Stellen erstelle. x soll von Benutzer festgelegt werden
|
|
||||||
/*Komprimieren:
|
|
||||||
2 Glieche aufeinanderfolgende Zahlen: 0
|
|
||||||
2 Unterschiedliche aufeinanderfolgende Zahlen: 1
|
|
||||||
|
|
||||||
1. Einlesen der Benutzereingabe
|
|
||||||
2. Void Funktion für das Generieren von Zufallszahlen
|
|
||||||
3. Sorierfunktion
|
|
||||||
4. Vergleichen Array 1,2 | 3,4 | 5,6 | ...
|
|
||||||
--> Wenn eins übrig ist --> in nächste Zeile übernehmen
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdarg.h>
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
@ -32,52 +17,65 @@ int input() {
|
|||||||
return eingabe;
|
return eingabe;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zahlenfolge(int laenge, int arr[]) {
|
void zahlenfolge(int eingabe, int arr[]) {
|
||||||
srand(time(NULL));
|
srand(time(NULL));
|
||||||
for(int i = 0; i < laenge; i++) {
|
for (int i = 0; i < eingabe; i++) {
|
||||||
arr[i] = rand() % 2;
|
arr[i] = rand() % 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int vergleich(int arr[], int laenge) {
|
|
||||||
|
|
||||||
while (
|
void vergleich(int arr[], int laenge) {
|
||||||
for(int i = 0; i < laenge; i++) {
|
while (laenge > 1) {
|
||||||
if(arr[i] == arr[++i]) {
|
int neueLaenge = laenge / 2;
|
||||||
arr[i] = 0;
|
if (laenge % 2 != 0) {
|
||||||
printf("%d", 0);
|
neueLaenge++;
|
||||||
} else {
|
|
||||||
arr[i] = 1;
|
|
||||||
printf("%d", 1);
|
|
||||||
}
|
}
|
||||||
eingabe = eingabe % 2 + eingabe/2;
|
|
||||||
|
int neuesArray[neueLaenge];
|
||||||
|
|
||||||
|
|
||||||
|
for (int i = 0; i < laenge / 2; i++) {
|
||||||
|
neuesArray[i] = arr[i * 2] ^ arr[i * 2 + 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (laenge % 2 != 0) {
|
||||||
|
neuesArray[neueLaenge - 1] = arr[laenge - 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
for (int i = 0; i < neueLaenge; i++) {
|
||||||
|
printf("%d", neuesArray[i]);
|
||||||
|
}
|
||||||
|
printf("\n");
|
||||||
|
|
||||||
|
|
||||||
|
for (int i = 0; i < neueLaenge; i++) {
|
||||||
|
arr[i] = neuesArray[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
laenge = neueLaenge;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
|
|
||||||
int array[1000];
|
int array[1000];
|
||||||
int eingabe = input();
|
int eingabe = input();
|
||||||
zahlenfolge(eingabe);
|
zahlenfolge(eingabe, array);
|
||||||
for(int i = 0; i < eingabe; i++) {
|
|
||||||
printf("%d ", array[i]);
|
|
||||||
}
|
for (int i = 0; i < eingabe; i++) {
|
||||||
|
printf("%d ", array[i]);
|
||||||
|
}
|
||||||
|
printf("\n");
|
||||||
|
|
||||||
|
|
||||||
|
vergleich(array, eingabe);
|
||||||
|
|
||||||
printf("Eingegebene Länge: %d\n", eingabe);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Created by Lennart Pecher on 09.04.25.
|
// Created by Lennart Pecher on 09.04.25.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user