C :: Aufgabe #5 :: Lösung #2

3 Lösungen Lösungen öffentlich
#5

Ausgabe Weihnachtsbaum

Anfänger - C von Gustl - 07.12.2012 um 18:44 Uhr
Schreiben Sie ein Konsolenprogramm welches einen Weihnachtsbaum ausgibt.
Vor der Ausgabe soll noch die Höhe des Weihnachtsbaum abgefragt werden. (MIN 3)
Der Weihnachtsbaum soll bei einer Höheneingabe von 10 folgendermaßen aussehen:

Konsolenausgabe:

      *
***
*****
***
*****
*******
*****
*******
*********
###


Die Schwierigkeit besteht in den Stufenabschnitten der Tanne. Die Zeile die die meisten Sterne enthält sollte natürlich dann auch die letzte sein, also muss das Programm vielleicht bei einer zu großen Höheneingabe das Zeichnen der Sterne abbrechen und dann den Stamm ausgeben. (So wie bei diesem Beispiel, angegeben ist 10 aber der Baum hat nur 10 Reihen, ohne Baumstamm)

#2
vote_ok
von mraimbot (590 Punkte) - 08.01.2019 um 01:01 Uhr

Konsolenausgabe:

\C-Aufgaben> .\Aufgabe-0005.exe
Wie viele Reihen soll ein Baumteil haben?: 3
Wie gross soll der Baum werden (in Zeilen)?: 10
*
***
*****
***
*****
*******
*****
*******
*********
###

\C-Aufgaben> .\Aufgabe-0005.exe
Wie viele Reihen soll ein Baumteil haben?: 5
Wie gross soll der Baum werden (in Zeilen)?: 11
*
***
*****
*******
*********
*******
*********
***********
*************
***************
###
Quellcode ausblenden C-Code
///////////////////////////////////////////////////////////
//! @file Aufgabe-0005.c
//! @date 08.01.2019
//! @author Sebastian Schröder
//! @details
//! Compiler    : gcc 5.1.0
//! C-FLAGS     : -pipe -std=c99 -Wall -Wextra -pedantic -Werror -D_DEFAULT_SOURCE -O0 -g -o Aufgabe-0005.exe Aufgabe-0005.c
//! Testumgebung: Windows 10 - Windows PowerShell
//!
//! Aufgabe: Ausgabe Weihnachtsbaum
//! Schreiben Sie ein Konsolenprogramm welches einen Weihnachtsbaum ausgibt.
//! Vor der Ausgabe soll noch die Höhe des Weihnachtsbaum abgefragt werden. (MIN 3)
//! Der Weihnachtsbaum soll bei einer Höheneingabe von 10 folgendermaßen aussehen:
//! Konsolenausgabe:
//! 
//!       *
//!      ***
//!     *****
//!      ***
//!     *****
//!    *******
//!     *****
//!    *******
//!   *********
//!      ###
//! 
//! Die Schwierigkeit besteht in den Stufenabschnitten der Tanne. Die Zeile die die meisten Sterne enthält
//! sollte natürlich dann auch die letzte sein, also muss das Programm vielleicht bei einer zu großen Höheneingabe
//! das Zeichnen der Sterne abbrechen und dann den Stamm ausgeben. (So wie bei diesem Beispiel, angegeben ist 10
//! aber der Baum hat nur 10 Reihen, ohne Baumstamm)
///////////////////////////////////////////////////////////


#include <stdio.h>
#include <stdlib.h>


#define TREEOFFSET 3


void printTree(int treeHeight, int treePartSize);
int getNumber (int min, const char *output);


int main (/*int argc, char **argv*/) {
	printTree (getNumber (3, "Wie gross soll der Baum werden (in Zeilen)?: "), getNumber (2, "Wie viele Reihen soll ein Baumteil haben?: "));
	return EXIT_SUCCESS;
}


void printTree(int treeHeight, int treePartSize) {
	treeHeight--;
	int sizeLastPart = treeHeight % treePartSize;
	int numParts = treeHeight / treePartSize + (sizeLastPart == 0 ? 0 : 1);
	int numSegments = 0;
	int currTreePartSize;
	int centerPos = numParts * (treePartSize - 1) - numParts + TREEOFFSET + 1;
	int i;
	
	for (int partID = 0; partID < numParts; ++partID) {
		currTreePartSize = (partID == numParts -1 && sizeLastPart > 0) ? sizeLastPart : treePartSize;
		for (int row = 0; row < currTreePartSize; ++row) {
			/* print offset */
			for (i = 0; i < TREEOFFSET; ++i) {
				printf (" ");
			}
			/* print free room on left side */
			for (i = TREEOFFSET; i < centerPos - numSegments; ++i) {
				printf (" ");
			}
			/* print left side of tree */
			for (i = 0; i < numSegments; ++i) {
				printf ("*");
			}
			/* print center of tree */
			printf ("*");
			/* print right side of tree */
			for (i = 0; i < numSegments; ++i) {
				printf ("*");
			}
			printf ("\n");
			numSegments++;
		}
		numSegments -= 2;
	}
	/* print trunk of tree */
	for (i = 0; i < centerPos - 1; ++i) {
		printf (" ");
	}
	printf ("###\n");
}


int getNumber (int min, const char *output) {
	int value = 0;
	int check = 0;
	char ch;

	do {
		printf ("%s", output);
		check = scanf ("%i", &value);

		while ((ch = getchar ()) != '\n' && ch != EOF);

		if (1 != check) {
			printf("Eingabe ungueltig. Eingabe muss eine positive Ganzzahl sein.\n");
		}

		if (min > value) {
			printf("Eingabe ungueltig. Eingabe muss mindestens %i betragen.\n", min);
			check = 0;
		}
	} while (check != 1);
	
	return value;
}


#undef TREEOFFSET

Kommentare:

Für diese Lösung gibt es noch keinen Kommentar

Bitte melden Sie sich an um eine Kommentar zu schreiben.
Kommentar schreiben