Swift Playground 有一關是要用「右手規則」去解題,由於從來沒聽過什麼「右手規則」,就查了一下。
一開始找不到什麼相關的文章,改試了一下 right hand rule 跳出來的是物理的右手原則,和解題沒什麼關聯。
試了好幾組關鍵字,最後是用 maze right hand rule 找到維基百科的 maze solving algorithm 。
記錄一下在解題過程中和「右手規則」相處的心得。
做對每一件小事,做對每一個細節,能夠做到一百分的事,就不要只做六十分敷衍過去。
即將消失的自助新村.眷村裡迷路.舊草嶺環狀自行車道 20 公里行.西部小旅行:阿里山森林鐵路車庫園區&北門車站.台糖烏樹林休閒園區.永保安康&橋頭糖廠.打狗鐵道故事館&駁二.旗山.里港&屏東.彰化扇形車庫.大肚成功.出島計畫:馬公.北環.湖西+南環.馬公.支線之旅:平溪.舊山線.林口線.鼻頭角步道.野柳地質公園.猴硐.七堵鐵道公園.一滴水紀念館.淡水.淡水天元宮賞櫻.烏來.土城桐花祭.三芝天使光.桃園忠烈祠.南部旅行:板橋→台南.台南→永康→保安→橋頭→左營→鼓山→旗津→鳳山.鳳山→竹田→枋寮→加祿→古莊→鳳山.鳳山→台南→台中→新竹→板橋.一個人環島:楔子.台北→花蓮.花蓮→台東.台東→枋寮→南州→鳳山→高雄→鳳山.鳳山→高雄→二水→集集→車埕→台中.台中→新竹→竹東→內灣→竹東→新竹→板橋
未完待續…
Swift Playground 有一關是要用「右手規則」去解題,由於從來沒聽過什麼「右手規則」,就查了一下。
一開始找不到什麼相關的文章,改試了一下 right hand rule 跳出來的是物理的右手原則,和解題沒什麼關聯。
試了好幾組關鍵字,最後是用 maze right hand rule 找到維基百科的 maze solving algorithm 。
記錄一下在解題過程中和「右手規則」相處的心得。
之前用 d3.js 畫了台灣高鐵列車運行圖,當時還在用 v4 。v5 其實去年就發佈了,一直沒做升級,最近才去研究怎麼升級。
由於用到了 d3.csv()
,也就是這次 v4 到 v5 不相容的部份,試了很久才試出來 v5 的寫法。
就結果而言其實只改動了不到 20 個字元,有點意外就是。
做完升級以後順手用了 PageSpeed Insights 測載入速度,87 分不能再高了 XD
最近一個練習用的案子需要用到字串輸出。由於是在 console 端輸出,所以就想要把輸出結果對齊。用了 sprintf 這個 php 內建的功能和官網文件上的範例,拼拼湊湊試了很久,把想要的結果印好之後,回頭檢查才發現每一行我下的參數都不大一樣,於是花了點時間研究一下。
如果需要對齊的字串是 ASCII 範圍內的字元,基本上沒有問題:
>>> sprintf('%-80s: test', 'abcdefg hijklmnop qrstuv wxyz 1234567890 !@#$%^&*()-={}[]|\;:\'",<.>/?') => "abcdefg hijklmnop qrstuv wxyz 1234567890 !@#$%^&*()-={}[]|\;:'",<.>/? : test"
要對齊的字串出現一些歐語系常見的字母時,就開始有問題了:
>>> sprintf('%-80s: test', 'ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞß¼½¾') => "ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞß¼½¾ : test"
更不用說中日韓語系字元了:
>>> sprintf('%-80s: test', '許茹芸淚海慶功宴吃蓋飯') => "許茹芸淚海慶功宴吃蓋飯 : test" >>> sprintf('%-80s: test', 'あかさたなはまやらわイキシチニヒミイリウィ') => "あかさたなはまやらわイキシチニヒミイリウィ : test" >>> sprintf('%-80s: test', 'アカサタナハマヤラワイキシチニヒミイリウィ') => "アカサタナハマヤラワイキシチニヒミイリウィ : test" >>> sprintf('%-80s: test', '트와이스 나연 정연 모모 사나 지효 미나 다현 채영 쯔위') => "트와이스 나연 정연 모모 사나 지효 미나 다현 채영 쯔위 : test"
目前要印的資料剛好沒有遇到 CJK ambiguous width 的問題,所以就直接手動調整 %s
的數字解決…當然如果是在不需要等寬對齊的狀況,就沒有這個問題了。
因為一些奇怪的需求,需要在 json 中做一些奇怪的檢查,然後研究了一下怎麼檢查 null
這個值,做點記錄…
最近在進行的一個案子中,其中一個需求是要透過 API 取得 JSON ,然後再把 JSON 的內容組成適當的 HTML 顯示出來。
因為 JSON 並不會處理掉 <
>
之類的字元,原本想說大概是要寫個類似字串替換的程式,把 <
>
自行代換成 <
>
之類的。
後來 google 了一下,找到一個還蠻方便的寫法,就寫一篇記下來…
今天很難得用到 git apply
,所以記錄一下。
會想要用 git rebase
,單純只是因為 git merge
會產生類似 merge branch 'master' of blah
的訊息。
不過由於後來有遇到一點問題,不確定做法是不是對的,就先做個記錄…
狀況大概是這樣: 一個字串變數的可能值是 ABCD...YZ 26個英文大寫字母。是 ADE...YZ 的時候,執行 if
裡的條件;是 B 或 C 的時候,要執行 else
裡的條件式。
一開始學的是最簡單的:
<?php
if ($a) {
echo "Apple";
} elseif ($b) {
echo "Boy";
} else {
echo "Cat";
}
?>
JavaScript 提供了 pseudo protocol 的方式,可以在 html 裡做一些應用。
當初是寫某個東西時,需要在 MySQL 環境下,下一個像這樣的 SQL 指令:
一開始的想法是用 php 。
Subversion 其中一個功能就是回復。
這是最近在處理一個奇怪的地方碰到的。