Ir ao conteúdo
  • Cadastre-se

Flávio Pedroza

Membros Plenos
  • Total de itens

    189
  • Registro em

  • Última visita

  • Qualificações

    N/D
  1. this.interfoneTableAdapter.Conferir(txtRamal.Text).ToString() Não o string, objeto é que null se this.interfoneTableAdapter.Conferir(txtRamal.Text) == NULL, e você chamar .ToString() vai gerar um exceção e a execução do programa vai pular para o catch.
  2. teste = exclui->proximo-1; teste->proximo = exclui->proximo; Não entendi muito bem o que você quis fazer neste trecho? Porque subtrai 1 do ponteiro?
  3. "Quando a busca encontra algo, o código não da erro, mas quando é o retorno é null" Ora, se o retorno do metodo "Conferir(txtRamal.Text)" for null, é natural que der erro "System.NullReferenceException" quando você chama o método toString. você pode tratar esse caso no catch e mostrar uma messagem do tipo "Ramal Inexistente". Ou com if private void btEnviar_Click(object sender, EventArgs e) { try { resp = this.interfoneTableAdapter.Conferir(txtRamal.Text).ToString(); if (!String.IsNullOrEmpty(resp)) { MessageBox.Show("Este interfone já foi reportado por " + resp, "Aviso"); } else { ... } } catch (System.NullReferenceException ex) { MessageBox.Show("Este interfone não existe", "Erro"); }
  4. Acredito que sim. Ja troquei de placas com chipset diferentes (h61 para h110 - troquei até o processador) e mantive o mesmo sistema operacional. Conseguir dar boot e fazer o backup e posteriormente formatei.
  5. Não necessariamente, mas talvez o sistema fique instável. Caso perceba problemas de estabilidade, faça backup dos arquivos e formate.
  6. Nas duas tem aux->prox != NULL, mas acho que entendi. Veja se consegue entender pelo exemplo abaixo, com 3 nós. A condição é verificada antes de executar o que tem dentro do laço. Como pode ver, o laço com aux != NULL tem uma iteração a mais. Nós: No1 No1->prox = No2; No2->prox = No3; No3->prox=NULL; Inicio aux = No1 No. Interação | Verificar condição (aux->prox != NULL) | Executa imprima aux->valor? 1 | Falso | Sim, faça aux = No2 2 | Falso | Sim, faça aux = No3 3 | Verdadeiro (aux->prox = NULL) | NÃO Fim do laço Inicio aux = No1 No. Interação | Verificar condição (aux != NULL) | Executa imprima aux->valor? 1 | Falso | Sim, faça aux = No2 2 | Falso | Sim, faça aux = No3 3 | Falso | Sim, faça aux = NULL 4 | Verdadeiro (aux == NULL) | NÃO Fim do laço
  7. Mostra um exemplo de código que dá erro.
  8. A alocação permanece na memória até a próxima re-inicialização do sistema. Chamar free em uma variável que não foi previamente alocada na memória com malloc, calloc, etc. dará erro.
  9. Não percebi diferença entre os dois trechos de código, me parecem exatamente iguais.
  10. void addAluno(){ string nomeT; string codigo; vector<Aluno*> v_aluno; vector<Turma*> v_turma; (...) void addTurma(){ string nomeT; string codigo; vector<Aluno*> v_aluno; vector<Turma*> v_turma Esses vetores que você declarou são locais, só existem dentro do método. Após o fim do método, eles são deletados da memória. Bote eles como membros da class. você inclusive faz isso com o v_turma, mas declara novamente dentro do método, o que está errado. OBS.: Lembre-se que C++ não tem garbage collection ok? Para cada "new" você tem que chamar o "delete" correspondente, caso contrário você enche a memória.
  11. float area_total(cilindro *c){ float at =0; //at = area_base(&c); //at += area_lateral(&c); at = area_base(c); at += area_lateral(c); return at; } //float (*p[4])(float r, float a) = {area_base,area_lateral,volume,area_total}; float (*p[4])(cilindro *c) = {area_base,area_lateral,volume,area_total}; printf("Digite o raio e a altura:\n"); scanf("%f%f", &raio, &alt); iniciar(&c,raio,alt); printf("Escolha uma operação de 0 a 3:\n"); scanf("%d", &e); resp = (*p[e])(&c); printf("%f", resp); system("pause"); return 0; } Encontrei estes erros no seu código.
  12. #include <string.h> ... // NovoElemento->nome[TAMANHO] = v_nome; strcpy(NovoElemento->nome, v_nome); //NovoElemento->artista[TAMANHO] = v_artista; strcpy(NovoElemento->artista, v_artista); ... //printf("Nome da música: %c\n", ElementoVarredura->nome); printf("Nome da música: %s\n", ElementoVarredura->nome); //printf("Artista: %c\n", ElementoVarredura->artista); printf("Artista: %s\n", ElementoVarredura->artista); Achei esses erros no seu código.
  13. #include<stdio.h> #include <stdlib.h> #include<math.h> /*Declaraçoes da função*/ float media (int n, float *vnotas); int main (void) { float vnotas[10]; float media_notas; int i; float numero =0; i = 0; while ((numero >= 0) && (i < 10)) { printf("Digite os valores das notas: "); scanf("%f", &numero); if (numero >= 0) { vnotas[i] = numero; i++; } } media_notas = media (i, vnotas); printf ( "\nMedia = %.1f \n", media_notas); system("pause"); return 0; } /* Função para cálculo da média */ float media (int n, float *vnotas) { int i; float m = 0, soma = 0; /* Somatorio das notas*/ for (i = 0; i < n; i++) soma = soma + vnotas[i]; /*dividindo para realizar a media*/ m = soma / n; return m; }
  14. i = 0; while ((numero >= 0) && (i < 10)) { printf("Digite os valores das notas: "); scanf("%f", &numero); if (numero >= 0) { vnotas[i]) = numero; i++; } } media_notas = media(i,vnotas);
  15. #include <stdio.h> #include <stdlib.h> int main(void) { char baseDadosMusicasTitulos[10][30] = {"Ring of fire", "Hurt", "Brianstorm", "Do me a favour", "Turn it again", "I walk the line", "Wet sand", "Aint no grave", "Riders in the sky", "The man comes around"}; int baseDadosMusicasCodificadas[10][40] = {{10,24,33,78,54,92,10,29,36,96,2,66,87,54,-1}, {57,33,20,2,99,87,120,33,69,87,41,1,97,41,23,127,17,-1}, {74,11,20,36,87,62,36,96,77,42,36,38,77,21,22,9,77,8,-1}, {1,22,74,56,98,125,37,32,75,99,2,3,40,-1}, {95,43,55,7,91,63,53,10,24,44,81,6,-1}, {87,64,28,33,40,41,94,72,63,104,99,115,33,-1}, {5,65,95,21,30,14,107,51,50,67,111,121,34,72,91,55,-1}, {64,63,22,78,18,99,21,123,4,95,9,42,32,14,17,52,-1}, {7,66,12,20,87,119,32,44,89,21,3,89,16,4,58,1,1,57,10,21,-1}, {17,10,13,1,7,23,36,54,124,100,32,20,27,89,66,32,-1}}; int NA,vet[10],i,j, k, vetm[10], count = 0; for (int i=0; i < 10; i++) { printf("Musica: %d.%s\n",i+1, baseDadosMusicasTitulos[i]); } printf("Digite o tamanho da amostra da musica:"); scanf("%d",&NA); for(i=0; i<NA; i++){ printf("Digite os numeros da amostra da musica:"); scanf("%d",&vet[i]); } for(i=0; i<10; i++){ for(j=0; j<30; j++){ count = 0; for(k=0; k<NA; k++){ if (vet[k] == baseDadosMusicasCodificadas[i][k+j]) { count++; } else break; } if (count == NA) break; //achou a musica } if (count == NA) break; } //if (vetm[10] == baseDadosMusicasCodificadas[10][40] && baseDadosMusicasTitulos[10][30]){ if (count == NA) printf("A musica econtrada e : %s" , baseDadosMusicasTitulos[i]); else printf("A musica nao foi encontrada"); return 0; }

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações 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...

GRÁTIS: minicurso “Como ganhar dinheiro montando computadores”

Gabriel TorresGabriel Torres, fundador e editor executivo do Clube do Hardware, acaba de lançar um minicurso totalmente gratuito: "Como ganhar dinheiro montando computadores".

Você aprenderá sobre o quanto pode ganhar, como cobrar, como lidar com a concorrência, como se tornar um profissional altamente qualificado e muito mais!

Inscreva-se agora!