Vectores y Matrices en C

February 8th, 2010

Uff! esto de las clases estan pesadas y gracias a Dios, el trabajo esta en su auje.

Bueno el profesor de Programación nos solicito 6 programas; como lo comente antes por falta de tiempo por el trabajo no pude hacer mas que 3 y ya teniendo el agua hasta el cuello me tuve que desvelar y aqui estoy trabajando a altas horas de la noche con mi blog y mis códigos.

Use funciones, arreglos, y sobre toda, ocupe toda la lógica posible por que como a las 1:35 ya me estaba desesperado, agradezco a mi esposa el tiempo que me permite trabajar en mis proyectos escolares y espero que también ella pronto se este desvelando en sus trabajos escolar, solo que siendo como es de responsable veo difícil que a ella le pase lo que a mi.

Aquí el código de como podemos manejar algunas matrices y vectores en lenguaje C; para cada programa ocupe una función del tipo void y en mi main ocupe un switch para hacer el menu si alguien conoce una forma mas fácil y simple de hacer menus hecheme la mano no! y para rematar ocupe el mentado goto que todo mundo lo odia pero no se por que si saca de un par de apuros siempre:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
#include<stdio.h>
#include<conio.h>
#include<dos.h>
#include<stdlib.h>
#include<math.h>
/* ACENTOS Y EÑES
á –> \xA0
é –> \x82
í –> \xA1
ó –> \xA2
ú –> \xA3
ñ -> \xA4
*/

void primero() {
int a[4], i ;
printf("Aplicaci\xA2n que solicita 5 valores, los almacena en un array y los imprime.");
printf("\n Dame el primer valor: ");
scanf("%d",&a[0]);
printf("\n Dame el segundo valor: ");
scanf("%d",&a[1]);
printf("\n Dame el tercer valor: ");
scanf("%d",&a[2]);
printf("\n Dame el cuarto valor: ");
scanf("%d",&a[3]);
printf("\n Dame el quinto valor: ");
scanf("%d",&a[4]);
for(i=0; i<5; i++) {
printf("\n El \xA1ndice %d es %d", i, a[i]);
}
printf("\n \n") ;
system("pause");
}

void mayordetodos() {
int elementos[10], N, nmayor=0, mayor=0, I, Imenosuno=0 ;
printf("Ingrese el n\xA3mero de elementos que desea comparar: ") ;
scanf("%d", &N) ;
system("cls") ;
for(I=0;I < N; I++) {
printf("\nDame el elemento no. %d: ", I);
scanf("%d", &elementos[I]);
if (elementos[I] >= nmayor) {
mayor = I ;
nmayor = elementos[I] ;
}
}
printf("\nEl n\xA3mero mayor es el elemento %i que es %d \n", mayor, elementos[mayor]) ;
system("pause") ;
}
void sumapares() {
int s, i, numero, sumapares=0, sumaimpar=0;
float par ;
printf("Hacer una aplicacion que solicite N n\xA3meros y que sume pares e impares del arreglo creado") ;
printf("\n De cuantos valores sera el arreglo: ");
scanf("%d", &s);
s = s + 1 ; /* Sumo uno para eliminar el elemento 0 de mi arreglo */
int VectorMaestro[s];
for (i=1; i<s; i++) {
/*Inicie i en 1 por que elimine el elemento 1 de mi arreglo, y aun asi mantengo el tamaño que me asignaron */
printf("\n Dame el valor %d: ", i);
scanf("%d", &numero);
VectorMaestro[i] = numero ;
/* ocupe esto para verificar que estaba haciendo las cosas bien: printf("\t Numero sumado es %d", VectorMaestro[i]) ; */
/* Ya tengo mi vector, ahora voy a sumar pares e impares mediante la regla basica todo numero par dividido entre 2 da de residuo 0 */
par = i % 2 ;
if (par != 0 ) {
sumaimpar = sumaimpar + VectorMaestro[i] ;
}
else {
sumapares = sumapares + VectorMaestro[i] ;
}
}

printf("\n La suma de los n\xA3meros pares es: %d \n ", sumapares);
printf("\n La suma de los n\xA3meros impares es: %d \n ", sumaimpar);
system("pause") ;
}

void multiconversa() {
int TamanoVector=0, i=0, j=0;
printf("Aplicaci\xA2n que lee dos arreglos unidemensionales de igual tama\xA4o, y forma un tercero con el producto de los elementos de los dos anteriores, tomados en orden contraverso, es decir el ultimo por el primero, y asi sucesivamente\n") ;
system("pause") ;
system("cls") ;
printf("\nDame el tama\xA4o de los vectores: ");
scanf("%d", &TamanoVector) ;
/*Seteo el tamaño de VectorUno, VectorDos y VectorFinal, los 3 del mismo tamaño*/
int VectorUno[TamanoVector], VectorDos[TamanoVector], VectorFinal[TamanoVector] ;
/*LLeno el VectorUno */
for(i=0 ; i<TamanoVector ; i++) {
/* Me aseguro que el vector tenga los datos en blanco */
VectorUno[i] = 0 ;
printf("\nDame el valor %d del VectorUno: ", i);
scanf("%d", &VectorUno[i]) ;
/* DEBUG printf("Valor %d", VectorUno[i]) ; */
}
system("cls") ;
/*LLeno el VectorDos */
for(i=0 ; i<TamanoVector ; i++) {
/* Me aseguro que el vector tenga los datos en blanco */
VectorDos[i] = 0 ;
printf("\nDame el valor %d del VectorDos: ", i);
scanf("%d", &VectorDos[i]) ;
/* DEBUG printf("Valor %d", VectorDos[i]) ; */
}
system("cls") ;
j = TamanoVector - 1 ; /* Me va a dar el ultimo elemento del  VectorDos */
/* Recorro el vector sumando VectorUno[i] con VectorDos[j]
en el vector VectorFinal que vamos a armar del mismo tamaño que los otros 2 */
for(i=0 ; i<TamanoVector ; i++) {
/* Me aseguro que el vector tenga los datos en blanco */
VectorFinal[i] = 0 ;
VectorFinal[i] = VectorUno[i] * VectorDos[j] ;
/* DEBUG printf("\nValor %d", VectorFinal[i]) ;
printf("\tValor de j es %d", j) ; */
j-- ; /*Un elemento menos en el VectorDos */
}
printf("El vector resultante es: \n");
/* Recorro el VectorFinal y arrojo el resultado */
for(i=0 ; i<TamanoVector ; i++) {
printf("\nVectorFinal[%d] es = %d", i, VectorFinal[i]) ;
}
printf("\n");
system("pause") ;
}
void ordenamientoarray() {
printf("Aplicacion que pide dos vectores de NA y NB elementos, solicite al usuario numeros para llenarlos, ordene ascendentemente cada vector y luego ordene ascendentemente todos los datos en un tercer vector\n") ;
int fin1, fin2, i, j, aux, TamanoVectorUno, TamanoVectorDos, TamanoVectorFinal,  VectorFinalLlenado;
printf("Dame el tama\xA4o del primer vector: ");
scanf("%d",&TamanoVectorUno);
printf("Dame el tama\xA4o del segundo vector: ");
scanf("%d",&TamanoVectorDos);
TamanoVectorFinal = TamanoVectorUno + TamanoVectorDos ; /* Sumando tamaños de los dos vectores, obtengo mi tamaño del tercer vector */
/* Seteo Vectores con los 3 valores */
int VectorUno[TamanoVectorUno], VectorDos[TamanoVectorDos], VectorFinal[TamanoVectorFinal];
/* Llenado de vectores */
VectorFinalLlenado = 0 ; /* De una ves aprovecho a llenar el vector 3, despues lo ordeno :D */
/*Vector Uno */
for(i=0 ; i<TamanoVectorUno ; i++) {
printf("Dame el valor de VectorUno[%d]: ", i) ;
scanf("%d", &VectorUno[i]) ;
VectorFinal[VectorFinalLlenado] = VectorUno[i] ;
VectorFinalLlenado++ ;
}
/*Vector Dos */
for(i=0 ; i<TamanoVectorDos ; i++) {
printf("Dame el valor de VectorDos[%d]: ", i) ;
scanf("%d", &VectorDos[i]) ;
VectorFinal[VectorFinalLlenado] = VectorDos[i] ;
VectorFinalLlenado++ ;
}
/* Ordeno el vector uno */
for(i=0; i<TamanoVectorUno; i++) {
j = i;
aux = VectorUno[i];
while(j>0 && aux<VectorUno[j-1]) {
VectorUno[j] = VectorUno[j-1];
j=j-1;
}
VectorUno[j] = aux;
}
/* Ordeno el vector dos */
for(i=0; i<TamanoVectorDos; i++) {
j = i;
aux = VectorDos[i];
while(j>0 && aux<VectorDos[j-1]) {
VectorDos[j] = VectorDos[j-1];
j=j-1;
}
VectorDos[j] = aux;
}
/* Ordeno el vector tres */
for(i=0; i<TamanoVectorFinal; i++) {
j = i;
aux = VectorFinal[i];
while(j>0 && aux<VectorFinal[j-1]) {
VectorFinal[j] = VectorFinal[j-1];
j=j-1;
}
VectorFinal[j] = aux;
}
/* Pa su mauser, ya tengo los 3 vectores y ahora que; pues los imprimo ingar */
/* fin1 y fin2, es solo extra mio para mejorar lo estetico */
system("cls");
printf("Tres Vectores, ordenados finalmente :-)\n") ;
printf("\t\tV1\t\tV2\t\tVFinal\n") ;
/* NOTA PARA EL PROFESOR: YA ME CANSE DE BUSCAR LA MANERA DE QUE CUANDO SEA UN CARACTER BASURA,
NO LO IMPRIMA, OPTE POR HACER UN IF PARA EVITARLO, PERO SI EL PRIMER VECTOR ES MAS GRANDE QUE
EL SEGUNDO SE VUELVE A HACER ASI QUE SI PUEDE DECIRME COMO EVITAR LA BASURA EN LOS ARREGLOS */
for(i=0, j=15; i < TamanoVectorFinal ; i++, j++) {
if(i<TamanoVectorUno) {
printf("\t\t%d\t\t%d\t\t%d\n", VectorUno[i], VectorDos[i], VectorFinal[i]) ;
}
else if(i<TamanoVectorDos) {
printf("\t\t\t\t%d\t\t%d\n", VectorDos[i], VectorFinal[i]) ;
}
else {
printf("\t\t\t\t\t\t%d\n", VectorFinal[i]) ;
}
}
system("pause") ;
}
void partidos() {
int PartidosyZonas[3][5], i, j, sumapri=0, sumapan=0, sumaprd=0, totalVotos=0, empate, huboganador;
char* ganador ;
/* El partido 1 es el PRI, 2 es el PAN y 3 es el PRD
; las zonas las lleno hasta completar el arreglo*/
/* PRI */
for(i=0, j=1 ; i<5 ; i++, j++) {
printf("Votos del PRILuche en la zona %d: ", j) ;
scanf("%u", &PartidosyZonas[0][i]) ;
sumapri = sumapri + PartidosyZonas[0][i] ;
}
/* PAN */
for(i=0, j=1 ; i<5 ; i++, j++) {
printf("Votos del PANuche en la zona %d: ", j) ;
scanf("%u", &PartidosyZonas[1][i]) ;
sumapan = sumapan + PartidosyZonas[1][i] ;
}
/* PRD */
for(i=0, j=1 ; i<5 ; i++, j++) {
printf("Votos del PRDuche en la zona %d: ", j) ;
scanf("%u", &PartidosyZonas[2][i]) ;
sumaprd = sumaprd + PartidosyZonas[2][i] ;
}
/*Ya tengo las votaciones, ahora a cingarle con el ordenamiento */
/*Saco el porcentaje, primero el total de votos*/
totalVotos =  sumaprd + sumapri + sumapan ;
float porcentajePRD, porcentajePRI, porcentajePAN ;
porcentajePRD = (sumaprd * 100) / totalVotos ;
porcentajePRI = (sumapri * 100) / totalVotos ;
porcentajePAN = (sumapan * 100) / totalVotos ;
/*Ya tengo los 3 porcentajes, ahora a ver cual es el mayor - PRIMERO VEAMOS SI EMPATAN NO */
if(porcentajePRD==porcentajePRI) ganador = "Empatar\xA2n el PRDuche y el PRILuche" ; empate = 1 ;
if(porcentajePRD==porcentajePAN) ganador = "Empatar\xA2n el PRDuche y el PANuche" ; empate = 1 ;
if(porcentajePRI==porcentajePAN) ganador = "Empatar\xA2n el PRILuche y el PANuche" ; empate = 1 ;
if(porcentajePAN==porcentajePRD) ganador = "Empatar\xA2n el PANuche y el PRDuche" ; empate = 1 ;
if(porcentajePAN==porcentajePRD && porcentajePAN==porcentajePRI) ganador = "Empatar\xA2n los 3" ;
if(porcentajePRD > porcentajePRI && porcentajePRD > porcentajePAN) ganador = "PRDuche" ;
if(porcentajePRI > porcentajePRD && porcentajePRI > porcentajePAN) ganador = "PRILuche" ;
if(porcentajePAN > porcentajePRI && porcentajePAN > porcentajePRD) ganador = "PANuche" ;
system("cls") ;
printf("RESULTADOS DE LAS ELECCIONES EN CIUDAD PELUCHE\n") ;
printf("\tZ1\tZ2\tZ3\tZ4\tZ5\tTotal\tPorcentaje\n");
for(i=0 ; i<3; i++) {
/* PRI - PAN - PRD */
if(i==0) printf("PRI"); else if(i==1) printf("\nPAN"); else printf("\nPRD") ;
for(j=0; j<5 ; j++) {
printf("\t%d", PartidosyZonas[i][j]) ;
}
if(i==0) printf("\t%d\t%f", sumapri, porcentajePRI); else if(i==1) printf("\t%d\t%f", sumapan, porcentajePAN); else printf("\t%d\t%f", sumaprd, porcentajePRD) ;
}
if(porcentajePRI>50 || porcentajePRD>50 || porcentajePAN>50) huboganador=1 ;
if(huboganador==1) {
printf("\n\nY el ganador unanime es: %s", ganador);
}
else {
printf("\nChale!, ninguno llego a mas del 50%");
if(empate==1) printf("\nY ademas hubo un empate %s", ganador) ;
}
printf("\n") ;
system("pause") ;
}

main() {
int opcion ;
menu:
system("cls") ;
printf("MENU \t\t Programado: <alfredo@chiapaspc.com.mx>");
printf("\n\nProgramas compilados en un solo menu, por favor elige el numero del programa que quieras probar:\n\n");
printf("\nPrograma 1: Almacenamiento de valor en un vector");
printf("\nPrograma 2: Mayor de todos los n\xA3meros que usted ingrese");
printf("\nPrograma 3: Suma de elementos pares e impares");
printf("\nPrograma 4: Multiplicaci\xA2n del primero con el ultimo");
printf("\nPrograma 5: Dos vectores ordenados, y un tercero con los dos vectores ordenados");
printf("\nPrograma 6: Elecciones en Ciudad Peluche");
printf("\n\nPara salir, solo presiona 7") ;
printf("\nSeleccion: ") ;
scanf("%d", &opcion);
if(opcion>7) {
printf("\nElige una opcion valida\n");
system("pause") ;
goto menu ;
}
system("cls") ;
switch (opcion) {
case 1:
primero() ;
break;

case 2:
mayordetodos() ;
break;

case 3:
sumapares() ;
break;

case 4:
multiconversa() ;
break;

case 5:
ordenamientoarray() ;
break;

case 6:
partidos() ;
break;

case 7:
exit(1);
break;
}
goto menu;
}

Si alguien ve algun problema, doble codigo o piensa que de alguna manera puedo mejorarlo ahi estan los comentarios saludos.

Aventura en Tapachula

January 24th, 2010

Me quede sin dinero en Tapachula, mi tarjeta se la comío un #$#%# cajero enfrente del parque. Así empieza mi anécdota, fui a pedir fiado un hotel a donde siempre llego contal ya soy cliente. Asi que me quede a dormir ahí, pero tuve que dejar mi teléfono y mi credencial de la escuela.

Hoy temprano, me las vi negras para poder retirar de Elektra un envío, pero gracias a Dios todo salio bien y ya estoy aqui en Tuxtla contándole esta historia… no se ustedes pero no me gustaría que me volviera a pasar… sin dinero, sin identificación y en una tierra que no es la tuya.

Si Dios permite también, vamos a salir de viaje esta semana con mi esposa; iremos a Reforma a ver si de regreso les traigo fotos para que vean lo caluroso que es esa ciudad, su atractivo principal es que es un municipio 100% petrolero pero de ahí en fuera el calor es insoportable.

Juanito o mono de circo?

January 8th, 2010

Hoy estaba viendo La Jornada, y super atinadisima la imagen que presenta hoy Rocha.

Entre los escandalos-tonterias en que este personaje esta envuelto estan:

1. Una acta falsa que la PGJDF ya investiga.

2. Un Amparo tonto, donde quiere regresar al cargo, mismo para el que no esta nisiquiera facultado segun declaraciones de él -> “Brugada hiba a ayudarme a manejar la delegación”

3. Un voto de castigo contra otro “Payaso” de nombre Andres Manuel; segun Juanito “AMLO se esta desquitando con él, de no haber ganado la Presidencia”.

4. Acusa a Ebrad de violar la Constitucion si no lo nombra delegado, pero no dice que Leyes.

5. 35 Abogados para su defensa, de los cuales a lo mejor solo sirva 1 los otros 34 solo son acarriados.

6. Su propio equipo de trabajo esta decepcionado de las payasadas del señor.

7. Ahora es actor, y Carmen Salinas le hace el paro.

Y podría seguir la gran lista de cosas que el Gobierno arma para mantener al pueblo entretenido y que reciban tan gustosos impuestos altos y nuevas leyes que afectan a los Mexicanos.

Sigamos pues…

PatternWall – Fondos Espectaculares.

December 29th, 2009

Cuando estamos creando paginas, es muchas veces complicado crear un fondo que luzca friki.

Este sitio web te facilita todo el trabajo, se pueden ver una gran variedad de fondos que puedes bajar, y lo mejor de todo es que este gran espacio es gratuito, dia a dia amplian el numero de patterns.

Cuando te gusta uno, le das clic y aparece de fondo de Web y asi podras ver como se ve, mas sencillo no creo que se pueda.

Visitar http://patternwall.com/

Recuperar tabla de particiones.

December 26th, 2009

Cuantas vaces te ha pasado que te llega un cliente con el disco todo desmadrado, o simplemente tu por error borraste la tabla de particiones o simplemente la modifcaste y ya no la quieres asi.
La utilidad en funcion se llama TestDisk y es propiedad de CGSecurity es OpenSource; alguna de las maravillas que hace las listo a continuacion:

  • Repara particiones dañadas, recupera particiones dañadas
  • Recupera el sector de arranque en FAT32
  • Reconstruye el sector de arranque en FAT12/FAT16/FAT32.
  • Repara tablas FAT
  • Recontruye sector de arranque NTFS
  • Recupera sector de arranque NTFS
  • Repara MFT usando espejo MFT
  • Recupera archivos de FAT, NTFS y ext2

Su uso es sencillo, para aquellos que nos acostrabamos a usar consola o simbolo de sistema, seleccionas el disco duro que quieras arreglar, de ahi seleccionas el tipo de particion y le damos Fix o alguna de las funciones que nos aparece ahi. Guardamos y cerramos el programa, reiniciamos el equipo y ya tenemos reparada la particion.

El soporte a sistemas de archivos es extensos, pasando por los FATS nuevos y viejos, asi como tambien los ext2, 3 de Linux, XFS, Novell, Reirser, etc…

Subi algunas fotos, para demostracion:

Personas de Firefox

December 22nd, 2009

Firefox lo vuelve a hacer, fijense que colocar imagenes en el explorador como fondo era antes posible pero tenias que hacer varias cosas como meterle manos a la configuracion.

Ahora con Personas, Firefox hace mas sencillo, fácil y sobre todo rapido esto. La interfaz y el diseño de Personas es dinamico, y ofrece una gran gama de opciones para todo tipo de gustos y preferencias.

Los usuarios podrán contribuir con diseños originales los cuales serán cargados a la lista actual en determinadas fechas. Todavía no hay detalles de como se realizarán estas operaciones pero pronto se sabra más sobre ellos.

Pagina oficial de PERSONAS

Mis repos

December 21st, 2009

Estos son mis repos, para que @rriostrujillo los use.Viene comentados algunos que son nuevos.

# deb http://gb.archive.ubuntu.com/ubuntu/ jaunty main restricted
# deb http://gb.archive.ubuntu.com/ubuntu/ jaunty-updates main restricted
# deb http://security.ubuntu.com/ubuntu jaunty-security main restricted
# See http://help.ubuntu.com/community/UpgradeNotes for how to upgrade to
# newer versions of the distribution.

deb http://gb.archive.ubuntu.com/ubuntu/ jaunty main restricted
deb-src http://gb.archive.ubuntu.com/ubuntu/ jaunty main restricted

## Major bug fix updates produced after the final release of the
## distribution.
deb http://gb.archive.ubuntu.com/ubuntu/ jaunty-updates main restricted
deb-src http://gb.archive.ubuntu.com/ubuntu/ jaunty-updates main restricted

## N.B. software from this repository is ENTIRELY UNSUPPORTED by the Ubuntu
## team. Also, please note that software in universe WILL NOT receive any
## review or updates from the Ubuntu security team.
deb http://gb.archive.ubuntu.com/ubuntu/ jaunty universe
deb-src http://gb.archive.ubuntu.com/ubuntu/ jaunty universe
deb http://gb.archive.ubuntu.com/ubuntu/ jaunty-updates universe
deb-src http://gb.archive.ubuntu.com/ubuntu/ jaunty-updates universe

## N.B. software from this repository is ENTIRELY UNSUPPORTED by the Ubuntu
## team, and may not be under a free licence. Please satisfy yourself as to
## your rights to use the software. Also, please note that software in
## multiverse WILL NOT receive any review or updates from the Ubuntu
## security team.
deb http://gb.archive.ubuntu.com/ubuntu/ jaunty multiverse
deb-src http://gb.archive.ubuntu.com/ubuntu/ jaunty multiverse
deb http://gb.archive.ubuntu.com/ubuntu/ jaunty-updates multiverse
deb-src http://gb.archive.ubuntu.com/ubuntu/ jaunty-updates multiverse

## Uncomment the following two lines to add software from the ‘backports’
## repository.
## N.B. software from this repository may not have been tested as
## extensively as that contained in the main release, although it includes
## newer versions of some applications which may provide useful features.
## Also, please note that software in backports WILL NOT receive any review
## or updates from the Ubuntu security team.
# deb http://gb.archive.ubuntu.com/ubuntu/ jaunty-backports main restricted universe multiverse
# deb-src http://gb.archive.ubuntu.com/ubuntu/ jaunty-backports main restricted universe multiverse

## Uncomment the following two lines to add software from Canonical’s
## ‘partner’ repository.
## This software is not part of Ubuntu, but is offered by Canonical and the
## respective vendors as a service to Ubuntu users.
# deb http://archive.canonical.com/ubuntu jaunty partner
# deb-src http://archive.canonical.com/ubuntu jaunty partner

deb http://security.ubuntu.com/ubuntu jaunty-security main restricted
deb-src http://security.ubuntu.com/ubuntu jaunty-security main restricted
deb http://security.ubuntu.com/ubuntu jaunty-security universe
deb-src http://security.ubuntu.com/ubuntu jaunty-security universe
deb http://security.ubuntu.com/ubuntu jaunty-security multiverse
deb-src http://security.ubuntu.com/ubuntu jaunty-security multiverse

##emesene crazy
deb http://ppa.launchpad.net/bjfs/ppa/ubuntu jaunty main
deb-src http://ppa.launchpad.net/bjfs/ppa/ubuntu jaunty main

Ska-P Discografía

December 21st, 2009

Si duda, cuando hablamos de ska antisocial, no podemos pasar hablar de este excelente grupo español que le ha dado muchos dolores de cabeza al gobierno, religion y a las empresas privadas.

La primera ves que yo los escuche fue en el vive Latino del 2000 en donde tambien se presentaron grupos como SEKTA CORE y PANTEON ROCOCO de los cuales hasta el momento soy adepto.

Bueno para no hacerselas mucho de jamon aqui les dejo su discografia, si hay un enlace roto me lo comentan y si falta alguno tambien para subirlo saludos.

Ska-p – en vivo pepsi music
http://www.megaupload.com/?d=6PI3N3E8
http://www.megaupload.com/?d=UO9AG550

Ska-P – Eurosis
http://www.megaupload.com/?d=4S93RIRA

Ska-P – Incontrolable
http://www.megaupload.com/?d=35YJ3BVW

Ska-P – Planeta Eskoria
http://www.megaupload.com/?d=BB9FFAF2

Ska-P – Que Corra La Voz
http://www.megaupload.com/?d=YASJCZ74

Ska-P – Vals del Obrero
http://www.megaupload.com/?d=PTKH4GO5

Ska-p – Ska-p
http://www.megaupload.com/?d=D7UURUNT

2008 – Lágrimas y Gozos
http://www.megaupload.com/?d=RFDCU4MD

Geany IDE

December 21st, 2009

Les juro que deseaba ya tener un blog con dominio propio y archi requetecontra recomendar Geany IDE,  que es un editor de texto realizado en GTK2, flexible gracias a los plugins.

Esta desarrollado para proveernos de un pequeño, pero sorprendentemente rapido IDE, realmente no necesita muchas dependencias de librerias externas.

Lo mejor de todo es que soprta una gran variedad de lenguajes para iluminar el codigo, ademas que puedes compilar al vuelo.

Sinceramente, lo he probado en C y me a parecido buenisimo lo unico que he hecho para que pueda programar en ANSI C es agregarle en -ansi en el menu de “Compilacion > Selecciona Inclusiones y Argumentos”.

Esto lo puedes hacer para la mayoria de los lenguajes, es rapido, es facil es Geany…

Pagina oficial de Geany

Bienvenido

June 11th, 2009

Hola, pues veran… el foro me lo han quitado por que usaba Vbulletin así que lo voy a cerrar el foro como tal, en un futuro si alguien desea crear una comunidad con fines iguales a los mios estare abierto; creo ahora tendre que mover mi anterior blog aqui.

Les explico lo que van a ver en este blog, un poco de todo:

  • Informacion sobre cms (Wordpress, Textpatterns, etc..)
  • Informacion sobre Linux, en especial uno puede hablar de lo que sabe (Crunchbang Linux)
  • Acer Aspire One, algunas cosas que le hago a mi aparatito con 8GB y 1.5GB de RAM
  • Mis materias escolares, Trabajos, Proyectos, Ejemplos, Solucionarios, etc…
  • deseos, caprichos, gustos y mas mios.
  • Critica a la politica y a la caja idiota (aka Television)
  • Un poco de Warez, un poco de software GPL o de libre distribucion
  • Fotos de comida, lugares y otras cosas…

Por la informacion que contendra este blog supongo que abra como adeptos como otros que tachen de igual que otros este blog, tienen la seccion de comentarios para hablar de lo que gusten, siempre y cuando no me ofendan a mi, ni a mis lectores si no pues borro los comentarios y yap.

Pues bueno, adelante