Ir ao conteúdo
  • Cadastre-se

C++ problema em inserir a variavel em qualquer posicao da lista conitgua


The Frost

Posts recomendados

So estou com problema na parte de inserir variaveis em qualquer posicao da lista 

 

 

 

 

 void insert(lista *l, char x) {
    if (l->last == MAXLIST) {
    printf("lista cheia!\n");
    return;
}  else {
    l->item[l->last] = x;
     l->last++;
      printf("\n %c inserido.\n",x);
}
}

 

 int main (){
       lista l1;
       char val;
       int pos, posi;
     int opt;
     create(&l1);
         do{
     printf("\n\n(1)- inserir\n");

    scanf("%i", &opt);
     system ("cls");
         switch(opt) {
    case 1:
    printf("\nInforme o valor a inserir: ");
    scanf(" %c", &val);
    insert(&l1, val);
    break;

Link para o comentário
Compartilhar em outros sites

42 minutos atrás, The Frost disse:

So estou com problema na parte de inserir variaveis em qualquer posicao da lista 

Que tipo de problema, por exemplo "não consigo imaginar como acontece" ou "consigo imaginar acontecendo mais não sei escrever em código". Qual dos dois lhe representa melhor? 

 

Edita teu código postando com code tag <>  conforme explicado nesse Botão code <> : como e para que usar?

Link para o comentário
Compartilhar em outros sites

Utilizando o programa de lista contígua, crie a função get e melhore o procedimento insert de forma que ele aceite uma posição de inserção.

o get eu consegui o problema e no insert tem que por ele na posição que o usuario pedir

#include <stdio.h>

#include <stdlib.h>

#include <conio.h>

#define MAXLIST 100


//Daniel Marcelo 

//Ciencias da Computação


typedef struct TLista{

char item[MAXLIST];

int first, last;

} lista;


void create(lista *l) {

l->first = l->last = 0;

}

int isEmpty(lista *l) {

   return (l->first == l->last);

}

void insert(lista *l, char x) {   

if (l->last == MAXLIST) {

printf("lista cheia!\n");

return;

} else {

l->item[l->last] = x;

l->last++;

printf("\n %c inserido.\n",x);

}

}

void deleta(lista *l, int pos) {

    int i;

pos;

char aux;

if ((pos >= l->last) || (isEmpty(l))) {

printf("\n erro, posicao nao existe.\n");

return;

} else {

aux = l->item[pos];

l->last--;

for (i = pos; i <= l->last; i++) {

    l->item = l->item[i + 1];

}

printf("\n %c removido.", aux);

}

}

void print(lista *l) {

int i;

printf("\n\nItens da lista:\n");

for (i=l->first; i < l->last; i++) {

printf("%i:%c ",i, l->item);

}

}

int main (){

 lista l1;

 char val;

 int pos;

   int opt;

   create(&l1);

       do{

     printf("\n(1)- inserir\n");

   printf("\n(2)- remover\n");

   printf ("\n(3)- listar\n");

   scanf("%i", &opt);

        switch(opt) {

case 1:

printf("\nInforme o valor a inserir: ");

scanf(" %c", &val);

insert(&l1, val);

break;

case 2:

printf("\nInforme a posicao do item a remover: ");

scanf("%i", &pos);

deleta(&l1, pos);

break;

case 3:

print(&l1);

break;

}

}

while (opt!=4);{

    printf("obrigado");

}

} 

 

Link para o comentário
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...