137 lines
4.0 KiB
C#
137 lines
4.0 KiB
C#
namespace array_funzioni_4;
|
|
|
|
class Program
|
|
{
|
|
const int dimensione = 10;
|
|
static void Main(string[] args)
|
|
{
|
|
Console.Clear();
|
|
//dichiarazione e inizializzazione variabili
|
|
int scelta;
|
|
int[] array = new int [dimensione];
|
|
|
|
//menu
|
|
do{
|
|
Console.WriteLine("Scegliere un'opzione:");
|
|
Console.WriteLine("1. Stampa zig zag");
|
|
Console.WriteLine("2. Somma pari dispari");
|
|
Console.WriteLine("3. Array invertito");
|
|
Console.WriteLine("4. Tre consecutivi");
|
|
Console.WriteLine("5. Uno doppio dell'altro");
|
|
Console.WriteLine("0. Esci");
|
|
Console.Write("Scelta: ");
|
|
scelta=Convert.ToInt32(Console.ReadLine());
|
|
|
|
|
|
switch(scelta){
|
|
case 0:
|
|
Console.Clear();
|
|
break;
|
|
case 1:
|
|
Console.Clear();
|
|
array = CreaArrayCasuale();
|
|
StampaArrayZigZag(array);
|
|
Pausa();
|
|
break;
|
|
case 2:
|
|
Console.Clear();
|
|
array = CreaArrayCasuale();
|
|
Console.WriteLine(StampaPariDispari(array));
|
|
Pausa();
|
|
break;
|
|
case 3:
|
|
Console.Clear();
|
|
Pausa();
|
|
break;
|
|
case 4:
|
|
Console.Clear();
|
|
Pausa();
|
|
break;
|
|
case 5:
|
|
Console.Clear();
|
|
Pausa();
|
|
break;
|
|
default:
|
|
Console.WriteLine("Errore: scelta non valida");
|
|
Pausa();
|
|
break;
|
|
}
|
|
}
|
|
while(scelta!=0);
|
|
}
|
|
static void Pausa(){
|
|
Console.WriteLine("Premere un tasto per continuare. . .");
|
|
Console.ReadKey();
|
|
Console.Clear();
|
|
}
|
|
|
|
static int[] CreaArray(){
|
|
int[] ritorno=new int[dimensione];
|
|
int i=0;
|
|
string input;
|
|
|
|
do{
|
|
Console.Write("Inserire un numero, massimo " +dimensione+ " numeri ([q] per uscire): ");
|
|
input=Console.ReadLine(); //non posso ancora fare il catch dell'eccezione se viene inserito un qualcosa che non sia un numero o q
|
|
if(input!="q"){
|
|
ritorno[i]=Convert.ToInt32(input);
|
|
}
|
|
i++;
|
|
}
|
|
while(input!="q" && i<dimensione);
|
|
return ritorno;
|
|
}
|
|
|
|
static int[] CreaArrayCasuale(){
|
|
Random caso = new Random();
|
|
int[] ritorno=new int[dimensione];
|
|
|
|
for(int i=0; i<dimensione; i++){
|
|
ritorno[i] = caso.Next(1, 10);//sostituire 1, 10 con Int32.MinValue, Int32.MaxValue quando è pronto tutto
|
|
}
|
|
return ritorno;
|
|
}
|
|
|
|
static void StampaArray(int [] p_array) {
|
|
for (int j=0; j<p_array.Length; j++){
|
|
Console.WriteLine("Elemento " +j+ ": " +p_array[j]);
|
|
}
|
|
}
|
|
|
|
static void StampaArrayZigZag(int[] p_array){
|
|
int j=dimensione-1, k=0;
|
|
for (int i=0; i<dimensione; i++){
|
|
Console.Write("Elemento " + i + ": ");
|
|
if(i%2!=0){
|
|
Console.WriteLine(p_array[j]);
|
|
j--;
|
|
}
|
|
else{
|
|
Console.WriteLine(p_array[k]);
|
|
k++;
|
|
}
|
|
}
|
|
}
|
|
|
|
static string StampaPariDispari(int[] p_array){
|
|
int sommaPari=0, sommaDispari=0, i=0;
|
|
string ritorno;
|
|
while(i<dimensione){
|
|
sommaPari=sommaPari+p_array[i];
|
|
i = i + 2;
|
|
}
|
|
i = 1;
|
|
while(i<dimensione){
|
|
sommaDispari=sommaDispari+p_array[i];
|
|
i = i + 2;
|
|
}
|
|
if (sommaPari == sommaDispari){
|
|
ritorno="Pari e dispari uguali";
|
|
}
|
|
else{
|
|
ritorno = "Pari e dispari diversi";
|
|
}
|
|
return ritorno;
|
|
}
|
|
}
|