Instantly convert code snippets from Go to Elixir with our free online code converter. Transform your code easily and accurately.
Experience the full potential of AI-driven code conversion and transformation!
We prioritize your code's security and privacy. Your code is not stored on our servers and is only temporarily processed for conversion. We use OpenAI's secure servers for the conversion process, ensuring your code remains confidential.
Go is a statically typed, compiled programming language designed at Google. Go is syntactically similar to C, but with memory safety, garbage collection, structural typing, and CSP-style concurrency.
Elixir is a functional, concurrent, general-purpose programming language.
package main
import (
"fmt"
"strings"
"unicode"
)
func isPalindrome(s string) bool {
// Clean the string
clean := strings.Map(func(r rune) rune {
if unicode.IsLetter(r) || unicode.IsNumber(r) {
return unicode.ToLower(r)
}
return -1
}, s)
// Check palindrome
for i := 0; i < len(clean)/2; i++ {
if clean[i] != clean[len(clean)-1-i] {
return false
}
}
return true
}
func main() {
fmt.Println(isPalindrome("A man, a plan, a canal: Panama")) // true
fmt.Println(isPalindrome("race a car")) // false
}
defmodule Palindrome do
def is_palindrome(str) do
clean = str
|> String.downcase()
|> String.replace(~r/[^a-z0-9]/, "")
clean == String.reverse(clean)
end
end
# Example usage
IO.puts Palindrome.is_palindrome("A man, a plan, a canal: Panama") # true
IO.puts Palindrome.is_palindrome("race a car") # false
package main
import "fmt"
func bubbleSort(arr []int) {
n := len(arr)
for i := 0; i < n; i++ {
for j := 0; j < n-i-1; j++ {
if arr[j] > arr[j+1] {
arr[j], arr[j+1] = arr[j+1], arr[j]
}
}
}
}
func main() {
arr := []int{64, 34, 25, 12, 22, 11, 90}
bubbleSort(arr)
fmt.Println(arr)
}
defmodule Sort do
def bubble_sort(list) when length(list) <= 1, do: list
def bubble_sort(list) do
{new_list, swapped} = bubble_step(list, [], false)
if swapped, do: bubble_sort(new_list), else: new_list
end
defp bubble_step([a, b | tail], acc, swapped) when a > b do
bubble_step([a | tail], [b | acc], true)
end
defp bubble_step([a, b | tail], acc, swapped) do
bubble_step([b | tail], [a | acc], swapped)
end
defp bubble_step([a], acc, swapped), do: {Enum.reverse([a | acc]), swapped}
defp bubble_step([], acc, swapped), do: {Enum.reverse(acc), swapped}
end
arr = [64, 34, 25, 12, 22, 11, 90]
IO.inspect Sort.bubble_sort(arr)
Convert Go to Python
Open ConverterConvert Go to JavaScript
Open ConverterConvert Go to TypeScript
Open ConverterConvert Go to Java
Open ConverterConvert Go to C
Open ConverterConvert Go to C++
Open ConverterConvert Go to C#
Open ConverterConvert Go to Dart
Open ConverterConvert Go to Ruby
Open ConverterConvert Go to Swift
Open ConverterConvert Go to Kotlin
Open ConverterConvert Go to Rust
Open ConverterConvert Go to Scala
Open ConverterConvert Go to PHP
Open ConverterConvert Go to R
Open ConverterConvert Go to Haskell
Open ConverterConvert Go to Julia
Open ConverterConvert Go to MATLAB
Open ConverterConvert Go to Lua
Open ConverterConvert Go to Assembly
Open ConverterConvert Go to Perl
Open ConverterConvert Go to Groovy
Open ConverterConvert Go to F#
Open ConverterConvert Go to Clojure
Open ConverterConvert Go to Delphi
Open Converter