Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #21 (permalink)  
Старый 06.07.2018, 11:26
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,118

RCTYBZ, вот тебе кагбэ полное решение...

<!DOCTYPE html>
<html>
<head>
<meta http-equiv='Content-Type' content='text/html; charset=windows-1251' />
<script src='https://code.jquery.com/jquery-latest.js'></script>
<!--
<script src="https://code.angularjs.org/1.3.9/angular.min.js"></script>
<script src="https://code.angularjs.org/1.3.9/angular-route.js"></script>
-->
<style type='text/css'>
</style>
<script type='text/javascript'>
$(function(){
	$.ajax({
		url: "tmp1.csp",
		success: function(Data){
			var h=Data.match(/\d+/g);
			var a=h.slice(1);
			h=h[0];
			alert('Высота волны - '+h);
			alert('Рельеф - '+a);
			h=getCount(a,h);
			alert('Воды - '+h);
		}
	});
	function getCount(array, h) {
	    var max = 0, sum = 0;
	    for (var i = 0; i < array.length; ++i) {
	        var item = array[i];
	        if (item >= h) {
	            break;
	        }
	        sum += Math.max(0, max - item);
	        max = Math.max(max, item);
	    }
	    return sum;
	};
});
</script>
</head>
<body>
</body>
</html>
Ответить с цитированием
  #22 (permalink)  
Старый 06.07.2018, 11:46
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,064


var arr = '1 2 3 2 3 4 5 1 4 6'.match(/\d+/g);
var max = 4;
function pit(arr, max)
{
   var puddle = 0, min;
   for (var i = 0; i < arr.length; i++) {
       if(max <= +arr[i]) break;
       if(min == void 0 && arr[i + 1] <  arr[i]) min = arr[i];
       if(min != void 0 && arr[i] > min) min = void 0;
       if(min != void 0) puddle += min - arr[i];
   }
  return puddle
}

var num = pit(arr, max) ;
alert(num);
Ответить с цитированием
  #23 (permalink)  
Старый 06.07.2018, 12:33
Новичок на форуме
Отправить личное сообщение для RCTYBZ Посмотреть профиль Найти все сообщения от RCTYBZ
 
Регистрация: 06.07.2018
Сообщений: 4

совсем не понятно, как выгрузить информацию из txt
есть отдельный файл текстовый только с цифровым значением - высота волн и углубления, не понятно, как открыть, взять данные, внести их в массив.
Можно попробовать открыть таким способом и вывести данные для наглядности
<!DOCTYPE html> 
<html>
<head>
<title>wave</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<input type="file" id="files" name="file" /> Read file: 
<span class="readButtons">
  <button>show text</button>
</span>
<div id="byte_range"></div>
<div id="byte_content"></div>

<script>
  function read(opt_start, opt_stop) {

    var files = document.getElementById('files').files;
    if (!files.length) {
      alert('file not selected');
      return;
    }

    var file = files[0];
    var start = parseInt(opt_start) || 0;
    var stop = parseInt(opt_stop) || file.size - 1;

    var reader = new FileReader();

    reader.onloadend = function(evt) {
      if (evt.target.readyState == FileReader.DONE) {
        document.getElementById('byte_content').textContent = evt.target.result;
      }    
    };	

    var blob = file.slice(start, stop + 1);
    reader.readAsBinaryString(blob);
  }
  
  document.querySelector('.readButtons').addEventListener('click', function(evt) {
    if (evt.target.tagName.toLowerCase() == 'button') {
      var startByte = evt.target.getAttribute('data-startbyte');
      var endByte = evt.target.getAttribute('data-endbyte');
      read(startByte, endByte); 
    }
  }, false);
      alert(file);
</script>

</head>
</html>
Ответить с цитированием
  #24 (permalink)  
Старый 06.07.2018, 12:56
Аватар для j0hnik
Профессор
Отправить личное сообщение для j0hnik Посмотреть профиль Найти все сообщения от j0hnik
 
Регистрация: 01.12.2016
Сообщений: 3,650

<input type="file">
<script>
var arr;
document.querySelector('input').onchange = function(){
	var fr = new FileReader();
	fr.onload = function(){
		arr=this.result.split(' ');
	};
	fr.readAsText(this.files[0]);
};
</script>
Ответить с цитированием
  #25 (permalink)  
Старый 06.07.2018, 13:01
Аватар для j0hnik
Профессор
Отправить личное сообщение для j0hnik Посмотреть профиль Найти все сообщения от j0hnik
 
Регистрация: 01.12.2016
Сообщений: 3,650

если там в несколько строк разбить на массив по новой строке и по пробелам
Ответить с цитированием
  #26 (permalink)  
Старый 06.07.2018, 13:32
Профессор
Отправить личное сообщение для Rise Посмотреть профиль Найти все сообщения от Rise
 
Регистрация: 07.11.2013
Сообщений: 4,662

Да так можно, самое простое:
var file = '4\n1 2 3 2 3 4 5 1 4 6';
var rows = file.split('\n');
var height = rows[0];
var depths = rows[1].split(' ');
console.log(height, depths);

Последний раз редактировалось Rise, 06.07.2018 в 13:42.
Ответить с цитированием
  #27 (permalink)  
Старый 06.07.2018, 13:37
Новичок на форуме
Отправить личное сообщение для RCTYBZ Посмотреть профиль Найти все сообщения от RCTYBZ
 
Регистрация: 06.07.2018
Сообщений: 4

не получается задать рабочий массив, чтобы вывести значение и проводить операции с ним, для решения задачи
как из отдельного файла взять данные и внести в массив, до сих пор не найден для меня ответ
и тут наверное так
arr=this.result.split(',');

Последний раз редактировалось RCTYBZ, 06.07.2018 в 13:43.
Ответить с цитированием
  #28 (permalink)  
Старый 07.07.2018, 22:59
Новичок на форуме
Отправить личное сообщение для RCTYBZ Посмотреть профиль Найти все сообщения от RCTYBZ
 
Регистрация: 06.07.2018
Сообщений: 4

так и не дошло, как вывести из файла в программу данные
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Помогите новичку понять принцип работы функций. Sonnet Общие вопросы Javascript 3 17.05.2016 12:36
Помогите понять) Garet jQuery 4 08.04.2015 20:59
Народ помогите бьюсь уже неделю не магу понять apercot Javascript под браузер 7 06.11.2014 14:08
помогите понять код с замыканием alexandr_poskrobka Общие вопросы Javascript 4 04.10.2012 21:44
Анимация. Помогите понять почему не работает. kadurban jQuery 4 08.07.2010 20:50