Informatico Specializzato
05-06-2011, 09:53
Buongiorno a tutti voi,sono nuovo del forum :) .Innanzitutto vi faccio i complimenti per come è strutturato il forum ;) .Allora,sono alle prese con un programma in c++,che ho svolto interamente.Tuttavia,il programma da me compilato non soddisfa in modo completo la traccia.Vi posto la traccia e il programma da me svolto.
//Siano assegnati in ingresso, da tastiera, due vettori di interi V1 e
//V2 di uguale riempimento n.
//Si progetti un programma che riceva in ingresso V1 , V2, n ed un intero k e
//inserisca in un terzo vettore V3 la
//somma di quegli elementi di V1 e di V2 di omologa posizione che sono
//entrambi dispari.Quindi si individui la posizione P del primo elemento di V3 il cui
//valore sia maggiore di k.
//Si stampino, infine, il
//vettore V3 il suo riempimento (n3) ed il valore di P.
#include <iostream>
#include <stdlib.h>
using namespace std;
const int MAX_ELEM=100;
const int MAX_LUN=100;
typedef char stringa[MAX_LUN+1];
void input_array(int V[],int n,stringa nome_array);
void input(int V1[],int V2[],int &n);
void input_k(int &k);
bool copia(int V1[],int V2[],int V3[],int n,int &n3);
bool ricerca(int V3[],int n3,int k,int &val,int &pos);
void output(int V1[],int V2[],int V3[],int &n,int &n3,int k,int val,int pos);
void restart(char &risp);
int main()
{
char risp;
do{
int V1[MAX_ELEM];
int V2[MAX_ELEM];
int V3[MAX_ELEM];
int n;
int n3;
int k;
int val;
int pos;
input(V1,V2,n);
input_k(k);
ricerca(V3,n3,k,val,pos);
output(V1,V2,V3,n,n3,k,val,pos);
restart(risp);
}while ((risp=='s') || (risp=='S'));
system("PAUSE");
return 0;
}
void input_array(int V[],int n,stringa nome_array){
int i;
do{
if(n<0){
cout<<"Non puo'essere inserito un riempimento negativo"<<endl;}
if(n>MAX_ELEM){
cout<<"Non puo'essere inserito un riempimento maggiore di"<<" "<<MAX_ELEM<<endl;}
}while((n<0) || (n>MAX_ELEM));
for(i=0; i<n; i++){
cout<<"Inserire"<<" "<<nome_array<<"["<<i<<"]=";
cin>>V[i];
}
cout<<endl;
}
void input(int V1[],int V2[],int &n){
cout<<"Inserire il riempimento dei vettori"<<":";
cin>>n;
cout<<endl;
input_array(V1,n,"V1");
input_array(V2,n,"V2");
}
void input_k(int &k){
cout<<"Inserire il valore di k"<<":";
cin>>k;
cout<<endl;
}
bool copia(int V1[],int V2[],int V3[],int n,int &n3){
bool trovato=false;
int i;
int j;
n3=0;
for(i=0; i<n; i++){
for(j=0; j<n; j++){
if((V1[i]==V2[i]) && (V1[i]%2!=0) && (V2[j]%2!=0)){
V3[n3++]=V1[i]+V2[i];
}
}
}
if(n3!=0)
trovato=true;
return trovato;
}
bool ricerca(int V3[],int n3,int k,int &val,int &pos){
int i=0;
bool trovato=false;
while((i<n3) && (!trovato))
if(V3[i]>k){
trovato=true;
val=V3[i];
pos=i;
}
else{
i++;}
return trovato;
}
void output(int V1[],int V2[],int V3[],int &n,int &n3,int k,int val,int pos){
int i;
if(copia(V1,V2,V3,n,n3)==true){
cout<<"Il nuovo vettore e'"<<":";
for(i=0; i<n3; i++){
cout<<V3[i]<<" ";
}
cout<<endl;
cout<<"Valore"<<":"<<pos<<endl;
}
else
cout<<"Il vettore risulta vuoto"<<endl;
}
void restart (char &risp){
do{
cout<<"Vuoi ripetere il programma? (s/n)"<<":";
cin>>risp;
}while((risp!='s') && (risp!='S') && (risp!='n') && (risp!='N'));
}
//Siano assegnati in ingresso, da tastiera, due vettori di interi V1 e
//V2 di uguale riempimento n.
//Si progetti un programma che riceva in ingresso V1 , V2, n ed un intero k e
//inserisca in un terzo vettore V3 la
//somma di quegli elementi di V1 e di V2 di omologa posizione che sono
//entrambi dispari.Quindi si individui la posizione P del primo elemento di V3 il cui
//valore sia maggiore di k.
//Si stampino, infine, il
//vettore V3 il suo riempimento (n3) ed il valore di P.
#include <iostream>
#include <stdlib.h>
using namespace std;
const int MAX_ELEM=100;
const int MAX_LUN=100;
typedef char stringa[MAX_LUN+1];
void input_array(int V[],int n,stringa nome_array);
void input(int V1[],int V2[],int &n);
void input_k(int &k);
bool copia(int V1[],int V2[],int V3[],int n,int &n3);
bool ricerca(int V3[],int n3,int k,int &val,int &pos);
void output(int V1[],int V2[],int V3[],int &n,int &n3,int k,int val,int pos);
void restart(char &risp);
int main()
{
char risp;
do{
int V1[MAX_ELEM];
int V2[MAX_ELEM];
int V3[MAX_ELEM];
int n;
int n3;
int k;
int val;
int pos;
input(V1,V2,n);
input_k(k);
ricerca(V3,n3,k,val,pos);
output(V1,V2,V3,n,n3,k,val,pos);
restart(risp);
}while ((risp=='s') || (risp=='S'));
system("PAUSE");
return 0;
}
void input_array(int V[],int n,stringa nome_array){
int i;
do{
if(n<0){
cout<<"Non puo'essere inserito un riempimento negativo"<<endl;}
if(n>MAX_ELEM){
cout<<"Non puo'essere inserito un riempimento maggiore di"<<" "<<MAX_ELEM<<endl;}
}while((n<0) || (n>MAX_ELEM));
for(i=0; i<n; i++){
cout<<"Inserire"<<" "<<nome_array<<"["<<i<<"]=";
cin>>V[i];
}
cout<<endl;
}
void input(int V1[],int V2[],int &n){
cout<<"Inserire il riempimento dei vettori"<<":";
cin>>n;
cout<<endl;
input_array(V1,n,"V1");
input_array(V2,n,"V2");
}
void input_k(int &k){
cout<<"Inserire il valore di k"<<":";
cin>>k;
cout<<endl;
}
bool copia(int V1[],int V2[],int V3[],int n,int &n3){
bool trovato=false;
int i;
int j;
n3=0;
for(i=0; i<n; i++){
for(j=0; j<n; j++){
if((V1[i]==V2[i]) && (V1[i]%2!=0) && (V2[j]%2!=0)){
V3[n3++]=V1[i]+V2[i];
}
}
}
if(n3!=0)
trovato=true;
return trovato;
}
bool ricerca(int V3[],int n3,int k,int &val,int &pos){
int i=0;
bool trovato=false;
while((i<n3) && (!trovato))
if(V3[i]>k){
trovato=true;
val=V3[i];
pos=i;
}
else{
i++;}
return trovato;
}
void output(int V1[],int V2[],int V3[],int &n,int &n3,int k,int val,int pos){
int i;
if(copia(V1,V2,V3,n,n3)==true){
cout<<"Il nuovo vettore e'"<<":";
for(i=0; i<n3; i++){
cout<<V3[i]<<" ";
}
cout<<endl;
cout<<"Valore"<<":"<<pos<<endl;
}
else
cout<<"Il vettore risulta vuoto"<<endl;
}
void restart (char &risp){
do{
cout<<"Vuoi ripetere il programma? (s/n)"<<":";
cin>>risp;
}while((risp!='s') && (risp!='S') && (risp!='n') && (risp!='N'));
}