-
Hola a todos y que tengan un muy buen día.
#include <stdio.h>
int main (int argc,char **argv){
char *a[] = {" *", " ***", " *****", " *******", "*********"};
int i=0, j=2;
for(; i<9; i++){
if(i >= 0 && i <= 4){
}
else{
j+=2;
}
}
return 0;
}
Bueno al fin lo logre, sin copiar a las muchas versiones que debe haber en internet, solo que me parece innecesarios los espacios que tuve que poner en el array de punteros “a”, supongo que debe haber otra manera.-
La consulta es, se puede introducir entre “%s” una variable entera para que quede de esta manera:
Int b = 7;
printf("\n %bs", a);
Me da error y no logro hacerlo de otra manera, cualquier sugerencia será bienvenida.-
Desde ya muchas gracias por el tiempo.-
Saludos.
Daniel
-
Hola, creo que la forma de ponerlo es:
Int b = 7;
printf("\n %i%s", b, a);
-
Hola chenech.
No obtengo el resultado esperado, parecería que no está contemplado en el prototipo de la función printf, de cualquier manera pude mejorar y de hecho optimizar mi código, sólo me falta hacerlo con el operador condicional (ternario), por el momento me falta un poco de práctica para lograrlo pero ya lo estoy intentando (si queréis darme una mano, te estaré muy agradecido).-
#include <stdio.h>
int main(){
int i=0, izq=5, der=5;
char ate[] = " ";
for(; i<10; i++){
if(i<5){
ate[izq] = '*';ate[der] = '*';
izq--;der++;
}
else{
izq++;der--;
ate[izq] = ' ';ate[der] = ' ';
}
}
return 0;
}
Saludos.
Daniel
-
El operador ternario funciona se puede usar normalmente en un if/else, de la siguiente forma:
in iValor, iResultado;
if(iValor == 0)
iResultado = 1;
else
iResultado = 0;
con el operador seria asi:
int iValor;
int iResultado = (iValor == 0) ? 1 : 0;
O sea, se pregunta por la condición y se asigna el primer valor o el segundo según sea cierta o no.
Los ceros y uno pueden ser perfectamente variables, lo he puesto asi para reducir código.
Un saludo.
-
Hola chenech
Muchas gracias por la ayuda, un solo favor más te voy a pedir, tan sólo decime si lo que quiero hacer (con el código de dejo a continuación) es factible, practique de todas maneras con paréntesis, punto y coma y nada, con solo saber que se puede hacer voy a seguir leyendo y practicando hasta lograrlo.-
#include <stdio.h>
int main(){
int i=0, izq=5, der=5;
char ate[] = " ";
for(; i<10; i++){
(i<5) ? ate[izq] = '*' ate[der] = '*' izq-- der++ : izq++ der-- ate[izq] = ' ' ate[der] = ' ';
}
return 0;
}
(http://i59.tinypic.com/a10hsh.png)
Saludos.
Daniel
-
Hola chenech
Muchas gracias por la ayuda, un solo favor más te voy a pedir, tan sólo decime si lo que quiero hacer (con el código de dejo a continuación) es factible, practique de todas maneras con paréntesis, punto y coma y nada, con solo saber que se puede hacer voy a seguir leyendo y practicando hasta lograrlo.-
...............................
Daniel
No soy chenech pero te ayudo igual.
Antes que nada ten en cuenta el uso de los pre y post incrementos ya que te aligeran el código, así como la igualación de dos variables:
#include <stdio.h>
int main(){
int i=0, izq=5, der=5;
char ate[] = " ";
for(; i<10; i++){
if(i<5)
ate[izq--] = ate[der++] = '*';
else
ate[++izq] = ate[--der] = ' ';
printf("\n %s", ate);
}
return 0;
}
Y respecto al operador ternario no te preocupes, es normal que al principio no te salga sobre todo con la cantidad de variables que incrementabas y post incrementabas por separado:
#include <stdio.h>
int main(){
int i=0, izq=5, der=5;
char ate[] = " ";
for(; i<10; i++){
(i<5) ? (ate[izq--] = ate[der++] = '*'):(ate[++izq] = ate[--der] = ' ');
printf("\n %s", ate);
}
return 0;
}
¡¡¡¡ Saluditos! ..... !!!!
(http://st.forocoches.com/foro/images/smilies/aaaaa.gif)
-
Hola leosansan
Maravilloso tú código ya estaba por desistir, tengo unas duditas para consultarte/consultarles.-
Si declaro la variable de esta manera funciona.
Si la declaro de estas otras 2 no me imprime ningún asterisco.-
Me podrían dar alguna explicación.-
Otra cosita, según tengo entendido el signo igual tiene asociatividad por la derecha pero esto no lo entiendo.-
ate[izq--] = ate[der++] = '*';
Saludos.
Daniel
-
Hola leosansan
Maravilloso tú código ya estaba por desistir, tengo unas duditas para consultarte/consultarles.-
Si declaro la variable de esta manera funciona.
Si la declaro de estas otras 2 no me imprime ningún asterisco.-
Me podrían dar alguna explicación.-
...............................
Estas llenando el array con nada, simplemente está vacío.
Tendrías que hacer algo como esto, y perdona que le halla cambiado el nombre al array:
#include <stdio.h>
int main(){
int i, izq, der,n;
do{
printf("\nBase del rombo(numero impar positivo): \n");
scanf("%d", &n);
}while ( n <=0 || (n % 2) == 0);
izq = der = --n/2;
char ch[n+1];
for(i=0; i<n; i++)
ch[i]=' ';
ch[i]='\0';
for(i=0; i<n; i++){
(i<n/2) ? (ch[izq--] = ch[der++] = '*'):(ch[++izq] = ch[--der] = ' ');
printf("\n %s", ch);
}
return 0;
}
Hola leosansan
.........................................................
Otra cosita, según tengo entendido el signo igual tiene asociatividad por la derecha pero esto no lo entiendo.-
ate[izq--] = ate[der++] = '*';
...............................
Te obsesiona la asociatividad pero en este caso no hay tal, simplemente hay una igualación de variables. :suerte:
¡¡¡¡ Saluditos! ..... !!!!
(http://st.forocoches.com/foro/images/smilies/aaaaa.gif)
-
Hola leosansan
Muy bien entendí todo sólo que en mi compilador MinGW no me permite declarar las variables en cualquier lado, tiene que ser todas al principio de la función Main.-
.........
izq = der = --n/2;
char ch[n+1];
for(i=0; i<n; i++)
.........
Saludos y gracias por tu tiempo.
Daniel
-
Hola leosansan
Muy bien entendí todo sólo que en mi compilador MinGW no me permite declarar las variables en cualquier lado, tiene que ser todas al principio de la función Main.-
.............................................
Yo también uso MinGW y lo único que lanza, estando en modo -Wall y -pedantic, es un warning, que no un error, porque no se ajusta al estándar C90 ya superado, así que tu problema se arreglará actualizando tu versión del MinGW o bien la del compilador que usas. Yo usualmente uso el Code::Blocks, por supuesto.
Por cierto, he visto que algo fallaba, creo, en el anterior código así que te lo paso revisado por si acaso:
#include <stdio.h>
int main(){
int i, izq, der,n;
do{
printf("\nBase del rombo(numero impar positivo): \n");
scanf("%d", &n);
}while ( n <=0 || (n % 2) == 0);
izq = der = --n/2;
char ch[n+1];
for(i=0; i<n; i++)
ch[i]=' ';
ch[i]='\0';
for(i=0; i<n; i++){
(i<n/2) ? (ch[izq--] = ch[der++] = '*'):(ch[++izq] = ch[--der] = ' ');
printf("\n %s", ch);
}
return 0;
}
¡¡¡¡ Saluditos! ..... !!!!
(http://st.forocoches.com/foro/images/smilies/aaaaa.gif)
-
Hola leosansan
El caso es que al compilar me sigue dando error y no me deja crear el ejecutable, voy a actualizar el compilador.-
(http://i58.tinypic.com/29zwhf9.png)
Saludos y gracias.
Daniel
-
Hola leosansan
El caso es que al compilar me sigue dando error y no me deja crear el ejecutable, voy a actualizar el compilador.-
.............................
Saludos y gracias.
Daniel
Mientras tanto puedes declarar el array inicialmente sobredimensionado:
#include <stdio.h>
int main(){
int i, izq, der,n;
char ch[100];
do{
printf("\nBase del rombo(numero impar positivo): \n");
scanf("%d", &n);
}while ( n <=0 || (n % 2) == 0);
izq = der = --n/2;
for(i=0; i<n; i++)
ch[i]=' ';
ch[i]='\0';
for(i=0; i<n; i++){
(i<n/2) ? (ch[izq--] = ch[der++] = '*'):(ch[++izq] = ch[--der] = ' ');
printf("\n %s", ch);
}
return 0;
}
Pero actualiza, es lo mejor.
¡¡¡¡ Saluditos! ..... !!!!
(http://st.forocoches.com/foro/images/smilies/aaaaa.gif)