Jump to content
matheus.leite

Alterar posição de arrays

Recommended Posts

Boa tarde pessoal !

Sou novo aqui no forum, então se eu postar algo errado me perdoe.

Amigos, sou novo com php e estou tendo problemas em achar uma solução. 

Tenho um array: 

$arrayCarro = array(
				   array(
				   		"Cor"=>$gol->getCor(),
						"Marca"=>$gol->getMarca(),
						"Modelo"=>$gol->getModelo(),
						"Ano"=>$gol->getAno()
				   ),
			 	   array(
			 	   		"Cor"=>$fusca->getCor(),
						"Marca"=>$fusca->getMarca(),
				       "Modelo"=>$fusca->getModelo(),
					    "Ano"=>$fusca->getAno()
				   ),
				   array(
			 	   		"Cor"=>$tg->getCor(),
						"Marca"=>$tg->getMarca(),
					   "Modelo"=>$tg->getModelo(),
					    "Ano"=>$tg->getAno()
				   )
			  );

e eu passo ele para um objeto do tipo 'Corrida', até ai tudo bem. Porém eu tenho uma function chamada 'ultrapassagem' e não faço a menor ideia de como poderia, de fato, fazer essa "ultrapassagem".

Este é o 'index.php':

<?php 
require 'classes/Carro.php';
require 'classes/Corrida.php';
$gol = new Carro();
$fusca = new Carro();
$tg = new Carro();

$gol->setCor("Rosa");
$gol->setMarca("Wolks");
$gol->setAno(2018);
$gol->setModelo("Sedan");

$fusca->setCor("Azul");
$fusca->setMarca("Wolks");
$fusca->setAno(2018);
$fusca->setModelo("4X4");

$tg->setCor("vermelho");
$tg->setMarca("TG sedan");
$tg->setAno(2098);
$tg->setModelo("Flat");


$arrayCarro = array(
				   array(
				   		"Cor"=>$gol->getCor(),
						"Marca"=>$gol->getMarca(),
						"Modelo"=>$gol->getModelo(),
						"Ano"=>$gol->getAno()
				   ),
			 	   array(
			 	   		"Cor"=>$fusca->getCor(),
						"Marca"=>$fusca->getMarca(),
				       "Modelo"=>$fusca->getModelo(),
					    "Ano"=>$fusca->getAno()
				   ),
				   array(
			 	   		"Cor"=>$tg->getCor(),
						"Marca"=>$tg->getMarca(),
					   "Modelo"=>$tg->getModelo(),
					    "Ano"=>$tg->getAno()
				   )
			  );


$corrida = new Corrida($arrayCarro);
$corrida->posicaoCarro();


Esta é a Classe Corrida:

<?php
class Corrida 
{
  
	private $arrayCarros;
	public function __construct($arrayCarros)
	{
		$this->arrayCarros = $arrayCarros;

		if(count($arrayCarros) > 0)
		{
			echo 'A corrida pode começar pois existe mais de um carro !'.PHP_EOL;
		} else {
			echo 'A corrida não pode começar pois existe apenas um carro :('.PHP_EOL;
			exit;
		}
	}
  
	public function iniciarCorrida()
	{
		echo 'Começando a corrida ...'.PHP_EOL;
		echo '1, 2, 3 e JÁ!!.' .PHP_EOL;
		echo '- A corrida começou ! Confira a posição inicial de cada carro: '.PHP_EOL;
		echo PHP_EOL;
		$this->posicaoCarro();

	}

	public function ultrapassagem()
	{
      	/*Aqui eu tentei fazer algo, porem ele apenas retira o último elemento do array
      		e o avança para direita, foi o mais próximo que consegui de uma 'Ultrapassagem'		*/
		$quantidadeCarros = count($this->arrayCarros);
		$auxiliar = $this->arrayCarros[$quantidadeCarros - 1];
		
		for ($i = $quantidadeCarros -1; $i > 0 ; $i--) { 
			$this->arrayCarros[$i] = $this->arrayCarros[$i -1];
		}
		$this->arrayCarros[0] = $auxiliar;
		echo 'Aconteceu uma ultrapassagem'.PHP_EOL;
		print_r($this->arrayCarros);
	}

  //Apenas uma função para 'melhorar' a exibição dos arrays.
	public function posicaoCarro()
	{
        $i = 1;
        foreach ($this->arrayCarros as $key => $value){
            echo 'Posição ['. $i++."] => ";
            print_r("Marca: " . $value['Marca'] . ", ");
            print_r("Modelo: " . $value['Modelo'] . ", ");
            print_r("Ano: " . $value['Ano'] . " ");
	        print_r("Cor: " . $value['Cor'] . " " .PHP_EOL);
	        echo PHP_EOL;
            
        }

    }

OBS: Existem N carros.

Um carro só pode passar o carro que esta na sua frente, por ex: Carro[1] pode  ultrapassar o Carro[0], porém  o Carro [2] não pode ultrapassar o Carro[0], apenas o Carro[1]. Após a ultrapassagem a lista dos carros deve ser reordenada.

 

Alguém poderia me ajudar ? 

Desde já agradeço !

Edited by matheus.leite
Colocando mais informações

Share this post


Link to post
Share on other sites

Olá, pode nos postar o seu cenário completo? O objeto Corrida, aonde ele fica armazenado (se é apenas em um array normal), etc...

Share this post


Link to post
Share on other sites
Em 03/09/2018 at 08:55, Gabriel Heming disse:

Olá, pode nos postar o seu cenário completo? O objeto Corrida, aonde ele fica armazenado (se é apenas em um array normal), etc...

Prontinho, perdão! xD

Share this post


Link to post
Share on other sites

Eu recomendaria criar um estrutura própria baseada em Data Structure.

 

De qualquer forma, usando apenas o que já existe, pode-se usar a Data Structure Vector ou Deque. Basicamente,  elas são sequencias que podem encolher/aumentar conforme a necessidade (a Deque leva vantagem nos métodos shift e unshif, que no seu caso pode ser usado em apenas um momento). O diferencial nelas serão os métodos insert e find, para alterar a posição entre eles.

$gol->setCor("Rosa");
$gol->setMarca("Wolks");
$gol->setAno(2018);
$gol->setModelo("Sedan");

$fusca->setCor("Azul");
$fusca->setMarca("Wolks");
$fusca->setAno(2018);
$fusca->setModelo("4X4");

$tg->setCor("vermelho");
$tg->setMarca("TG sedan");
$tg->setAno(2098);
$tg->setModelo("Flat");

//Insira diretamente os objetos na lista
// a posição deles assumida é
// 1 - Gol
// 2 - Fusca
// 3 - TG
$list = new \Ds\Deque([$gol , $fusca , $tg]);

Ultrapassagem:

// suponha-se que o tg ultrapasse o fusca

$position = $list->find($tg);

//valida se localizou o veículo
if ($position === false)
{
    // não esperamos esse erro, mas, se ocorrer, já sabe...
    throw new \UnexpectedValueException("Veículo não localizado");
}

if ($position === 0)
{
    // não esperamos esse erro, mas, se ocorrer, já sabe...
    throw new \InvalidArgumentException ("Veículo já é o primeiro colocado");    
}

// Método Ds\Deque::remove() remove o valor e retorna ele.
// O método Ds\Deque::insert() insere o valor na posição indicada, rearranjando a sequencia.
// Posição é sempre n - 1 (ou seja, a primeira é zero).
$list->insert($position - 1 , $list->remove($positon));

O interessante é que você não precisa dizer quem ele está ultrapassando, apenas dizer "qual carro" ultrapassou. O resto é tratado de forma uniforme.

 

Caso você queria que cada carro guarde a sua própria posição, pode usar o método Ds\Deque::apply que aplica uma função em todos os elementos da sequencia.

 

Se quiser ler um pouco mais sobre Data Structures, o seguinte link é do criador da biblioteca: https://medium.com/@rtheunissen/efficient-data-structures-for-php-7-9dda7af674cd

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By WitchMad
      Ooi gente!
      Seguinte, estou desenvolvendo uma plataforma para advogados. Nela será consultado processos a partir do web service do PJE.
      No site do PJE me recomendou utilizar o NuSoap para consultar o web service e foi o que eu fiz.
      Segue o código da consulta
      <?php require_once 'nusoap/lib/nusoap.php'; /* Parâmetros Requisitados */ // idConsultante // senhaConsultante // numeroProcesso /* Objetos de Resposta sucesso bollean Indica se houve sucesso na consulta do processo. mensagem string Mensagem informando que o processo foi consultado com sucesso. recibo xs:base64Binary Comprovante do protocolo do processo, que contém os dados básicos do processo. */ $wsdl = "https://www.tjpe.jus.br/pje/intercomunicacao?wsdl"; $client = new nusoap_client($wsdl, 'wsdl'); if($client->getError()){ echo "Erro no construtor" . $client->getError(); exit(); } $result = $client->call('consultarProcesso', array('idConsultante'=>'CPF do Consultante', 'senhaConsultante'=>'Senha do Consultante', 'numeroProcesso'=>'Número do Processo')); echo $result['sucesso']; ?> Acontece que a página fica em branco, sem nenhum tipo de mensagem.
      Se possível gostaria de dicas se há algum erro no código, ou alguma outra ferramenta para consultar web service
    • By Alvaro Pacífico Serpa
      Olá pessoal, eu estava copiando um trecho de um código fonte usando o file_gets_contents
      $log=file_get_contents($url); $trechoInicial = "VideoUrl('"; $trechoFinal = "')"; $posicao1 = strpos($log, $trechoInicial); $posicao2 = strpos( $log, $trechoFinal, $posicao1 ); $trechoCopiado = substr( $log, $posicao1 + strlen( $trechoInicial ), $posicao2 - $posicao1 - strlen( $trechoInicial ) ); echo $trechoCopiado; Estava funcionando perfeitamente e do nada parou de funcionar, tem alguma outra forma de fazer isto que estou fazendo?
    • By Leonardo Ortega
      Prezados, bom dia.
      sou novo por aqui, e me deparei com esta situação:
      estou desenvolvendo um projeto e tudo começou quando apenas mudei o banco de dados que estava conectado. Ou seja, se eu me conecto ao baco de dados anterior, volta todo código html, porém, se conecto ao banco de dados atual as divs desaparecem. 
       
      obs: Isso tb acontece quando eu desativo o php tudo volta como a imagem 1 e se eu ativo fica como a imagem2.
       
      quem pode me ajudar.. desde já muito obrigado.  


    • By Richard.Ribeiro
      Fala Pessoal.. Bom dia.. uma ajuda por favor.
      não sei se e a melhor opção mais, gostaria de criar um id sequencial id="material"
      para resolver seguinte problema.. com javascript eu crio select com dados selecionados anteriormente, e crio mais opção no caso de haver mais pedido, porém toda vez que preciso troca a categoria o PRIMEIRO selecte que já possui um item e resetado. como posso resolver isso O PRIMIEIRO SELECT NÃO MUDAR. uma vez que á possui value selected
       
      segue todo código:

        <div id="box" >
        <form id="cadastro"  method="post">
          <?php
            if(isset($_POST['acao'])){
              $ide = $_POST['ide'];
              $data = $_POST['data_pedido'];
              $username=$_SESSION['username'];
              $justificativa = $_POST['justificativa'];
              $id_tipo_material = $_POST['material'];
              $qnt_solicitada = $_POST['qnt_solicitada'];

              //cadastrar no banco de dados!
                  $gravar = new Painel();
                  $id_gsm = $gravar->cadastrarGsm($data,$username,$justificativa,$ide);
                  $gravar->cadastrarItem($id_gsm,$id_tipo_material,$qnt_solicitada);
                  Painel::alert('sucesso','Pedido realizado com sucesso!');
                  }
                  $ConsultaIde = ConexaoBD::conectar()->prepare("SELECT  vsat_gilat, 'IDE: '||vsat_gilat|| ', Situação:'|| situacao|| ', Localidade:'||localidade|| ', Logradouro: '||logradouro as local
        FROM vsat WHERE vsat_gilat != '' AND situacao = 'Ativo'");
                  $ConsultaIde->execute();
                  $ConsultaIde = $ConsultaIde->fetchAll();
        ?>
        <div >
        <div class="form-group">
              <label>Selecione uma IDE</label>
              <select class="ide" name="ide" id="ide" required>
                <option disabled selected>-- Selecione IDE --  </option>
                  <?php
                  foreach ($ConsultaIde as $key => $value) {
                    ?>
                    <option value="<?php echo $value['vsat_gilat'];?>">
                      <?php echo $value['local'];?>

                </option>
              <?php }?>
              </select>

              <label>Data da Solicitação do Material :</label>
              <input type="text"value="<?php   echo date('d/m/Y');    ?>"  name="data_pedido" readonly >
        </div><!--form-group-->
            <div class="form-group">
              <label>Justificativa do pedido:</label>
              <textarea  rows="8" cols="80" name="justificativa" required></textarea>
        </div><!--form-group-->

        <div class="form-group">
              <label>Selecione Sistema:</label>
              <select name="id_categoria" id="id_categoria">
              <option selected disabled> --- Selecione o Sistema ---</option>
            <?php
        $consulta= ConexaoBD::conectar()->prepare("SELECT id_sistema, descricaos FROM public.cadastrar_sistema");
        $consulta->execute();
        while($row_cat_post = $consulta->fetch(PDO::FETCH_ASSOC) ) {
        echo '<option value="'.$row_cat_post['id_sistema'].'">'.$row_cat_post['descricaos'].'</option>';
              }
        ?>
          </select>
        </div><!--form-group-->
        <div class="form-group">
          <label>Selecione Padrão:</label>
          <span class="carregando">Aguarde, carregando...</span>
          <select name="id_sub_categoria" id="id_sub_categoria" >
            <option value="">--- Selecione o Padrão ---</option>
          </select>
        </div><!--form-group-select-->

        </div>
        <div class="pedido">
          <div class="remover">
          <label>Selecione Material:</label>
          <span class="carregando">Aguarde, carregando...</span>
          <select name="material[]" id="material">
            <option value="">--- Selecionte o Material ---</option>
          </select>
          <input type="text" id="quantidade" name="qnt_solicitada[]" placeholder="Digite a Quantidade" >
      <button type="button" name="button" class="removedor">Remover Item</button>
      </div>
      </div>
      </div>
        <button type="button" name="button" class="clonador">Novo Item</button>
        <input type="submit" name="acao" value="Cadastrar!">
        </form>
       
       
       
       
       
       
       
        <script type="text/javascript" src="https://www.google.com/jsapi"></script>
                <script type="text/javascript">
                  google.load("jquery", "1.4.2");
                </script>
      <script  src="<?php echo INCLUDE_PATH_PAINEL ?>js/jquery-3.4.1.min.js"></script>
      <script type="text/javascript">
        $(function(){
          $('#id_categoria').change(function(){
            if( $(this).val() ) {
              $('#id_sub_categoria').hide();
              $('.carregando').show();
              $.get('sub_categorias_post?search=',{id_categoria: $(this).val(), ajax: 'true'}, function(j){
                html = $.parseHTML(j);
                j=JSON.parse(html[16].textContent.trim());
                var options = '<option value="">Escolha Subcategoria</option>';
                for (var i = 0; i < j.length; i++) {
                  options += '<option value="' + j.id + '">' + j.nome_sub_categoria + '</option>';
                }
                $('#id_sub_categoria').html(options).show();
                $('.carregando').hide();
              });
            } else {
              $('#id_sub_categoria').html('<option value="">– Escolha Subcategoria –</option>');
            }
          });
        });
        $(function(){
          $('#id_sub_categoria').change(function(){
            if( $(this).val() ) {
              $('#material').hide();
              $('.carregando').show();
              $.get('sub_categorias_post2?search=',{id_sub_categoria: $(this).val(), ajax: 'true'}, function(j){
                html = $.parseHTML(j);
                console.log(html);
                j=JSON.parse(html[16].textContent.trim());
                var options = '<option value="">Escolha Subcategoria</option>';
                for (var i = 0; i < j.length; i++) {
                  options += '<option value="' + j.id + '">' + j.nome_sub_categoria + '</option>';
                }
                $('#material').html(options).show();
                $('.carregando').hide();
              });
            } else {
              $('#id_sub_categoria2').html('<option value="">– Escolha Subcategoria –</option>');
            }
          });
        });
        </script>
        <script>
        $(document).ready(function(){
       
              $(document).on('click', '.clonador', function(e){
                var elm_html = $('.pedido').html();
                var counter = 0;  //faz uma cópia dos elementos a serem clonados.
                  e.preventDefault();
                  var elementos = elm_html.replace(/\[[0\]]\]/g, '['+ counter +']');  //substitui o valor dos index e incrementa++
                  counter++;
                  $('#cadastro').append(elementos);  //exibe o clone.
              });
          });

          $(document).on('click', '.removedor', function (event) {
            event.preventDefault();
            $(this).parents('.remover').remove(); // navega até o pai com a classe pedido e remove ele inteiro
          });
        </script>
       
        <?php
        die();
        ?>
      </div><!--box-content-->
    • By djwagnersp
      Bom dia amigos, tudo bem? estou com uma duvida se alguém puder me ajudar agradeço desde já.
       
      tenha a seguinte condição:
      //array dos produtos $prod = 'agua'; $prod = 'refri'; $prod = 'cerveja'; //array das quantidades $qtd = '3'; $qtd = '2'; $qtd = '6'; Gostaria de fazer um loop o for ou foreach que imprimisse o $prod a quantidade de vezes do $qtd
      como seria possível realizar isso?
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.