Ir ao conteúdo
  • Cadastre-se

Ansi C

Membro Pleno
  • Posts

    3.214
  • Cadastrado em

  • Última visita

Tudo que Ansi C postou

  1. Agora compreendo — aposta, sendo um sorteio manual dos números pelo apostador. ]
  2. Quem costuma chamar isso de aposta?
  3. Onde está tua maior dificuldade? Em C, na Geometria Plana? Quem sabe, talvez: nos dois assuntos? É possível ensinar/aprender programação na matemática, física, etc., inclusive havia nome para essa coisa: Informática para Educação. Entretanto! O melhor é expressar primeiro a solução matematicamente: com variáveis e resultados conhecidos, daí supostamente a solução c fluirá. Essa é minha sugestão: Se não fez, então, faça uma solução com lápis, borracha e um cebo de Geometria Plana, depois aplique sem pressa ao C.
  4. Eu entendo, e tu compreendes, que os programas são simulações\representações pouco ou quase nada perto da realidade material das coisas; logo, não existe o sorteio material, real ou manual em sistemas analógicos e digitais: há somente algoritmos. E DAÍ Supostamente, o exercício é algo acerca de iteração sobre vetores e números randomizados (ou qualquer coisa semelhante) que, para mim, resolve em Algoritmo de Embaralhamento. Sugiro que defina uma função que tem como argumento formal um vetor e que retorna o valor dum elemento desse vetor; bolas é um bom nome para o vetor. Antes exclua (aplique exclusão lógica) a bola sorteada de bolas. Além de retornar uma bola do vetor, aquela função aplica em bolas a cada chamada o algoritmo de embaralhamento, o que, para mim, confere razoavelmente com 'sorteio manual ': ação de agitar o saquinho de bolas e pegar uma. Acho que isso agradará teu professor! A mim, muito agradaria. ***Se essa não é a pergunta, então, desculpe-me.
  5. Abaixo, trago-lhes a lista com os 40 primeiros números amigáveis — para simples conferência. amigos.txt 01. 220 280 02. 1184 1210 03. 2620 2924 04. 5020 5564 05. 6232 6368 06. 10744 10856 07. 12285 14595 08. 17296 18416 09. 63020 76084 10. 66928 66992 11. 67095 71145 12. 69615 87633 13. 79750 88730 14. 100485 124155 15. 122265 139815 16. 122368 123152 17. 141664 153176 18. 142310 168730 19. 171856 176336 20. 176272 180848 21. 185368 203432 22. 196724 202444 23. 280540 365084 24. 308620 389924 25. 319550 430402 26. 356408 399592 27. 437456 455344 28. 469028 486178 29. 503056 514736 30. 522405 525915 31. 600392 669688 32. 609928 686072 33. 624184 691256 34. 635624 712216 35. 643336 652664 36. 667964 783556 37. 726104 796696 38. 802725 863835 39. 879712 901424 40. 898216 980984
  6. Eu concordo E, supostamente, será a partir do 10⁠º número amigável que o custo do cálculo aumentará; há outra estratégia para minuir o tempo de produção, gravar no disco (tabela.txt) os novos números gerados e servi-lo como a tabela de consulta e agilizar a produção naquela função para índices menores que os que já existem | Por exemplo amigos (10);/* * Isto gera e grava (.txt) 10 números amigavéis * e produz somente o 10o número no simulador */ Se chamasse a função para índices ≤ 10, sua resposta viria do arquivo (.txt). Enquanto, para índices maiores que 10, a ação é gravar no arquivo todos os números até o índice no argumento, e produzi-lo. É algo que, sem pressa, qualquer um consegue essa expressão em tempo (resposta); -- uma resposta que, para mim, é\seria das boas.
  7. Uma solução depende da adição (ou soma) dos divisores. Se fosse para mim, tu me satisfarias com uma função, uma que determine aquela soma. Isto abaixo tem potencial para declarar essa função. ~x~ Só que não; porque há n1 == n2 ou n1>n2 e neste caso eles não são amigos ou são amigos repetidos. Suponho que uma solução seja a determinação de pares amigos, porém teu código-fonte me inspira muito mais uma checagem: checa-se n1 e n2 são amigos. Isso me parece pouco certo! Espero mais por uma determinação do amigo a partir de um argumento como ordinal. Por exemplo: amigos (1);/* * Isto produzirá 220 284, * o primeiro par de amigos */ Suponho que assim teu professor ficará satisfeito — eu ficaria
  8. Entendo... E será durante o prompt que produz a saída ou não? Neste caso, depois que memoriza ('bufferiza') 10 idades? Teu código-fonte, inspira-me ser durante; ou seja, ler 10 idades, e o seu enunciado não; ou seja, solicitar 10 idade(s). Há diferença entre as ações. Concordo Supostamente, se há vetores no apontamento, então esse é o modo.
  9. @devair1010 organização e compartilhamento. Organização Aos iniciantes, quase sempre, inspira-se depositar declarações neste tipo. Vê-se, pelo menos, assim um para: Declaração de tipos ... macros ... funções ... variáveis globais coisas comuns com compartilhamento no projeto.
  10. @Gustavo Rossi0101 Qual a duvida, onde fica tua maior dificuldade? -
  11. @ignite137 Olá. Para expressar o PROCESSAMENTO com C, é requisito uma expressão com matemática. Semelhante o que já foi dito, a partir da informação de entrada determine a área da superfície total da caixa em metros quadrados (At m²): sendo a soma da área da superfície das 6 faces. At = 2xy + 2xz + 2yz Em seguida, suponha cada razão do enunciado. Sendo a primeira a quantidade de tinta total para o serviço, uma razão de um metro quadrado por 3 litros de tinta (1 m²/3l). At m²/(1 m²/3 l) › (At m² • 3 l) /m² › 3At litro(s) *Suponho a quantidade de tinta sendo o produto da área da superfícies por 3. Em seguida, para cada 10 metros quadrados é necessário um novo rolo de tinta que custa R$ 5,00 (10 m²/5 r › 2 m² /real) At m²/(2 m²/real) › (At m² • real) /2 m² › ½At real *Suponho o custo com rolos sendo a metade da área da superfícies. continua...
  12. Claro, e qual é probabilidade de erro nessa situação? Dum erro que é quase inexistente. Entretanto, culturalmente essa expressão vem com mais uma sentença -- c != EOF Ex. /*Um discarte mais seguro da linha*/ int c = 0; //isso declara a palavra auxiliar no discarte */ while (c != '\n' && c != EOF) /*isso expressa um discarte mais seguro da linha (por ciclo) enquanto a palavra diferir de 'ENTER' e EOF */ c = getchar (); //isso pega uma palavra (int) na linha É mais ou menos assim que os manuais expressão essas coisas, né? Para lógica não faz diferença, não é erro, com ou sem o tratamento.
  13. Erros Internos associados ao fluxo (Input/Output) nos são irrelevantes na compreensão da Lógica, é por esse motivo que, consideramos certas as expressões de @Midori @devair1010 Checar os estados dos fluxos padrões, por exemplo, com uso da função 'ferror', pouco ou quase nada adicionará as suas lógicas / expressões. Sendo mais didático, por exemplo: no caso da expressão do @Midori há pequeníssima possibilidade de ficarmos presos num laço infinito, bem ali, na expressão que nos aponta um descarregar do fluxo de entrada (padrão): while(getchar() != '\n'); # Um tratamento de erro while (getchar () != '\n' && ferror (stdin) == 0) ; Se, potencialmente, a getchar indicasse erro, veríamos o laço sem fim; apesar de tratável, o tratamento é irrelevante na compreensão dessa expressão, de sua lógica e entendimento.
  14. @Diego M. Santos Olá! Estou iniciante nesse assunto (ainda). Parece-nos sinistra a inter-relação. Porque entendemos, o primeiro sendo uma CLI e outro um Editor (supostamente) independentes. Logo, o que acontece se ousássemos instalar (Angular/CLI) a Interface de Linha de Comando do Angular e expressássemos diretamente duma Shell: ng --help, antes de instalar o VSCode ?
  15. @clara leal , Olá (outra vez), por motivos didáticos acrescentarei a mensagem (exemplificação) que, talvez, reforça a percepção de que o cerne não são os números inteiros (Z), porém -especificamente- os positivos (Z+). C'11 in GCC /* main.c --- Uma exemplificação duma variável de controle @ESPECIFICAÇÃO Exemplificação e verificação de user-prompt da informação [#] Agora para continuar com essa operação, diga-nos A QUANTIA de fichas Cliente"s no cadastramento. (0 = anulará operação)? @BUGs Caso falhem -especificamente- na informação (digitação), imprima-se: [!] erro--- quantia inválida. *sendo 'erro' aquela string faltosa. e repetir. @EXPRESSÃO C'11 into GCC 5.2.0 *** by Mauro B. 2024-2 v2 */ #include <stdio.h> int main (void) { int nfichas = (-1); /* sendo quantia de f- Cliente no cadastramento */ char prompt [BUFSIZ]; /* sendo mediador de tipos no cadastramento */ /* Como na interação user-prompt ... */ printf ("%s", "[#] Agora para continuar com essa operação,\n" "diga-nos A QUANTIA de fichas Cliente's para cadastramento.\n" "\n"); for (; printf ("%s", "(0 = anulará operação)? "), fgets (prompt, BUFSIZ - 1, stdin), sscanf (prompt, " %i", &nfichas), (nfichas <= 0) ;) if (nfichas) /* SE difere do 0 */ printf ("[!] %s--- quantia inválida.\n" "Dê-me quantia >= 0.\n\n", prompt); else /* SE 0 */ return (-1); /* retonar status FAILURE */ printf ("%s%d%s", "[#] Informou-nos A QUANTIA de: ", nfichas, " fichas.\n" "\n"); return (0); } /* retornar status SUCCESS */ Ilustração in MS Windows — Numa situação de uso comum, hipoteticamente, o laço encerra na informação de inteiro positivo ou 0 encerra. Entendeu-me nessa lógica /expressão ?
  16. Se diz provavelmente, então prove... Contudo, tuas opiniões (comentário mínimo) talvez ajude outro alguém… (senão tanto faz) Devemos e podemos COMENTAR TUDO.; até expressões simples e quem diz o contrário, quase sempre tem pouco ou quase nenhuma autoridade. Se estou errado, prove! Ex: c = a + b; /*c sendo soma de a e b */ c = a + b; /*c sendo soma de a e b */ — Excelentes Programadores \ professores \ tutores \ iniciantes com um pouco de experiência e até mesmo IA sabem ignorar esses comentários, independentemente de que os escreveu. De todo modo, agradeço à tentativa!
  17. Olá! Suponho haver semelhança entre o queres e o que necessitas. Portanto… Há necessidade (duma informação), sendo ela um elemento no conjuntos dos números inteiros positivos (Z+). Daí… Essa analise superficial foca numa variável de controle, porque, interessa-nos, talvez, o valor nela e não noutra. Logo… Parafraseando-se tua indagação, mais exemplo de interação num caso de uso comum; expressamos o código-fonte assim: C'11 in GCC /* main.c --- Uma exemplificação duma variável de controle @ESPECIFICAÇÃO Exemplificação e verificação de user-prompt da informação [#] Agora para continuar com essa operação, diga-nos A QUANTIA de fichas Cliente"s no cadastramento. (0 = anulará operação)? '''BUGs: Caso falhem -especificamente- na informação (digitação), imprima-se: [!] erro--- quantia inválida. *sendo 'erro' aquela string faltosa. e repetir. @EXPRESSÃO C'11 into GCC 5.2.0 *** by Mauro B. 2024-2 */ #include <stdio.h> int main(void) { int nfichas = (-1); /* sendo quantia de f- Cliente no cadastramento */ char prompt [BUFSIZ]; /* sendo mediador de tipos no cadastramento */ /* Como na interação user-prompt ... */ printf ("%s", "[#] Agora para continuar com essa operação,\n" "diga-nos A QUANTIA de fichas Cliente's para cadastramento.\n\n"); for (; printf ("%s", "(0 = anulará operação)? "), fgets (prompt, BUFSIZ - 1, stdin), sscanf (prompt, " %i", &nfichas), (nfichas <= 0) ;) if (nfichas) /* SE difere do 0 */ printf ("[!] %s--- quantia inválida.\n" "Dê-me quantia >= 0.\n\n", prompt), prompt [0] = '\0'; else /* SE 0 */ return (-1); /* retonar status FAILURE */ return 0; } /* retornar status SUCCESS */ Ilustração no MS Windows — Note a expressão / sentença para inteiro positivo (Z+) ou zero, onde qualquer diferente, hipoteticamente, será FALHA e continuará no seu laço. Isso talvez inspire uma expressão para o teu problema @clara leal
  18. Como quase sempre os fluxos são tipos agregados-lineares (Overwrite), essa solução consistirá na substituição daquele espaço em branco por um caractere de quebra de linha ('\n') — e não inserção. Olá @André T Franco — Semelhante o que já foi dito: Supostamente, essa tua solução ainda não será suficiente, porque a linha recém-definida teria uma soma de strings inferior a 16; essa situação, aparentemente, exige, quando possível, complementar 16 strings por linha, sendo a linha abaixo a fonte dessa complementação: supostamente, após encontrar aquela string de controle, envia-se à saída 16 strings e um quebra de linha (se possível, senão envia o resto).
  19. Quem falou que seus comentários foram desnecessários / qual autoridade? 'ÔXI'!!! A expressão é tua, comente-na livremente (se tem tempo: seja verborrágico). Não perda–tempo com regrinhas, recomendações de estilo e indentação esdrúxulas; se necessário, existem exemplos de expressões bem escritas na pasta da biblioteca padrão da linguagem de programação C. A propósito, alguns dos melhores guias para iniciantes tem comentários em TUDO; e somos autorizados por eles a sermos super didáticos até à nos mesmos. — Sugerem que, inicialmente, expressemos uma solução com algoritmo. Existem 3 tipos principais de algoritmo: a descrição narrativa, o fluxograma e o pseudocódigo. E daí? — Daí que, recomendam mais estudo no seu desenvolvimento lógico e expressão em algoritmo, em seguida, rebaixá-lo à linguagem C, usá-lo para documentar com comentários e aprender, porque a linguagem de programação é somente uma ferramente ( e C é uma das antigas); — Então Existem linguagens muito, …, muito mais idiomáticas que a linguagem C, e mesmo elas, não superam o algoritmo/lógica/comentário.
  20. O que dizem nos guias da Linguagem de Programação C? — Suponho que algo semelhante à String: é uma sequência finita de elementos dum alfabeto, sendo algum meio de variável ou constante literal de bytes contíguos, quase sempre legíveis, que na computação denotam array ou matriz normalmente de caracteres — porque, muitas vezes, depende dessa estrutura e tipo de dados. E daí? — Daí o motivo desta resposta Suponho que, dependendo da Filosofia C do autor, string denotará arranjo de char ou arranjo de qualquer tipo na implementação que estruturar o texto. Ou somente uma sequência de caracteres. Então — Concordo com @devair1010, porque tradicionalmente string é composta de dados legíveis por humanos sobre estrutura de dados de array de tipo caractere (char: byte).
  21. [Opinião]: Concordo contigo, reverter o legível para 'bem mais legível' faz sentido para aqueles que (ainda) enunciam. E vou além, destoa de refinamento do código-fonte, dizem uma etapa manual de otimização de software que a partir duma primeira solução, o refinamento define outra em expressões básicas e/ou eficientes; E daí? Daí responda, é possível equacionar/provar O eficiente e O Básico (S/N)? Se SIM, então o eficiente e o básico não são subjetivos. E o legível é! Refinamento do código-fonte, é uma etapa vital por volta de 1946 Hoje, para aqueles que deixam o compilador ajustar o código, meus sinceros parabéns porque o tempo é tudo. [Opinião]: As discussões, aparentemente, começam assim desse jeitinho e sendo C uma linguagem dita de cima para baixo, as soluções vão de sintética à analítica. Na realidade, têm-se muitas soluções para um mesmo velho problema. E não, eu não pesquisei, mas acredito que há muitas soluções de problemas semelhantes, quiça o mesmo problema com enunciado diferente. É uma oportunidade para aprender muito mais do que sugerem; no exercício da leitura do guia — suponho que tenha um ou mais guias de linguagem c para ler.
  22. Ah! Agradeço pela oportunidade de responder tuas perguntas sobre os compiladores: MinGW (definido para suporte ao GCC) GCC (sendo um conjunto (coleção) de compiladores da GNU). Os programas do gênero compilador (MinGW/GCC) são, para mim, seguramente bons. — Sinta-se a vontade para experimentar e perguntar.
  23. Suponho que sim, sendo MinGW um importante 'software' do gênero compilador, ele incluirá certamente essa especificação. E o GCC, sendo o seu conjunto de compiladores, também é capaz! Logo “MinGW o seu GCC para Microsoft Windows”. — Seja Um Windows ou Um sistema operacional do tipo Unix, o GCC seguramente suporta 4 subscritos. Boa pergunta, suponho haver uma formalização. Sendo, talvez, mais divertido observar. — Então, experimenta! #include <stdio.h> int main() { /* escreva mais subscritos [2] em sx até o limite do suporte */ static char sx[2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2][2] = {0}; // ok unsigned sx_meu_tamanho_e = sizeof sx; printf("O tam de sx e: %u byte.\n", sx_meu_tamanho_e); return 0; } * Não há perigo, adicione mais dimensões até o insuportável. — Meu palpite é que não passa de +126. — Espero que sim.
  24. Exemplifique um instante, talvez, ficará tudo ainda mais óbvio. Por exemplo, digamos que iniciou, passou-se 43876 milissegundos [supomos milissegundos sendo a unidade de tempo mais precisa em teu problema] E agora… com esse instante, qual a disposição e dígitos no LCD? — Palpito que estaria assim: 00:00:43 08 87 876
  25. @arfneto Olá! Eu ainda não entendo >< !

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...