c언어 질문 드립니다
영어 알파벳 오름차순으로 배열을 정리해야 되는 코딩입니다
strcpy없이 해야되는데 없이 하니까 l-value여야 한다는 오류가 나면서 자꾸만 실패하네요.찾아보니 다 strcpy만 쓰라는 말 밖에 없더군요 그 뒤로 더 해봤지만 소용이 없습니다. 어떻게 해야 할까요?
#include
#include
int main(void)
{
char names[10][20] = { "kim", "lee", "sin", "jo", "kim2", "chae", "jin", "bak", "so", "choi" };
int i, j;
char tmp[20];
printf("\n배열 초기화\n");
for (j = 0; j < 10; j++)
printf("%5s", names[j]);
printf("\n");
for (i = 0; i < 9; i++)
for (j = 0; j < 9 - i; j++)
if (strcmp(names[j], names[j + 1]) > 0)
{
[ tmp = names[j]; ]
| names[j] = names[j + 1]; |
| names[j + 1] = tmp; |
[ break; ]
}
printf("\nSorted Result\n");
for (j = 0; j < 10; j++)
printf("%5s", names[j]);
printf("\n");
return 0;
}
kldp에서 소스 코드는 code 태그 안에 쓰세요.
kldp에서 소스 코드는 code 태그 안에 쓰세요.
strcpy 쓰지 말라면 한 글자씩 복사하란 얘기같네요.
the c programming language github 검색해보면
C언어의 바이블이라 할 수 있는 책의 내용을 파일로 볼 수 있네요.
그 책 예제 중에 한 글자씩 복사하는 예제 보면 될 거 같고요.
에러가 난다면 에러 메시지 살펴보시고, 경고 메시지도 잘 살펴보셔요.
세벌 https://sebuls.blogspot.kr/
1. 왜 strcpy를 쓰면 안 되나요? 이 경우는
1. 왜 strcpy를 쓰면 안 되나요? 이 경우는 strcpy가 최적의 선택입니다.
2. cryptic한 컴파일러 에러 메시지는 짜증을 불러 일으키지요.
l-value를 필요로 한다는 컴파일러의 메시지는 사실 문제를 해결해준다기보다는 문제를 추가로 얹어 줍니다.
1) l-value란 무엇인가?
2) 어떤 맥락에서 l-value를 필요로 하는가?
3) 제시된 코드는 왜 l-value를 제공하지 못하는가?
를 알아야 하는데, 설명하기 매우 귀찮으니 생략합니다.
그렇다고 컴파일러를 너무 원망할 것까지는 없고요. 문제의 원인을 진단하고 알려주는 컴파일러의 능력에는 한계가 있을 수밖에 없습니다. 그래서 프로그래머의 역할이 중요한 거죠.
3. strcpy를 쓸 수 없다면 memcpy를 써도 괜찮은 상황이긴 하군요. 그나마도 안 된다면...
static void my_strcpy(char *dest, const char *src){ while(*dest++ = *src++); }
4. "네가_더_좋은_솔루션을_알더라도_그거_쓰지_마라" 따위의 문제는 진짜 꼴도 보기 싫습니다.
지극히 채점 편의주의적인 발상이지요.
물론 제 학점이 걸려 있을 때에는 참을 수 있었습니다. 남의 숙제일 땐 그렇지 않습니다.
만일을 대비해서 질문 원본을 기록으로 남겨둡니다.
만일을 대비해서 질문 원본을 기록으로 남겨둡니다.
http://archive.is/sDtos
왜 strcpy를 쓰면 안 되나요?
왜냐면... 숙제 내 준 선생님이 조건을 그리 주신 것 아닐까요?
세벌 https://sebuls.blogspot.kr/
저 문제의 정확한 의도를 모르겠지만, 정렬된 결과만을
저 문제의 정확한 의도를 모르겠지만, 정렬된 결과만을 원하는 경우에는 strcpy 없이 하는 편이 더 좋습니다.
https://hamji.tistory.com/131
[OT] 감사드립니다...^^^
wjddmlwbslqj//
선생 덕분에 제가 며칠동안 고민해왔던것[*]이 해결되었어요.
진심으로 감사드립니다. 문제점 잘 해결되시길 바랍니다...
파이썬3 드림
[*] https://gitlab.com/soyeomul/test/-/commit/0fcf6b7f434eb2f19bea0da1893311eb9e51144e
[우분투 18.04 파여폭스 나비에서 적었어요~]
보여주신 코드는 멀티바이트 문자열을 사용한 것입니다.
보여주신 코드는 멀티바이트 문자열을 사용한 것입니다. 그 인코딩은 구현 및 로케일에 따라 다릅니다.
한국어 Windows에서는 멀티바이트 문자열을 cp949로 인코딩하던가요...
C언어에서는 아직 언어 차원에서 utf-8 encoding을 보장해 주는 지원이 없습니다.
C++에도 아직 없긴 한데, C++20부터 char8_t가 추가될 예정입니다.
아이고 농사꾼의 어설픈 글에 소중한 댓글 감사드립니다
아이고 농사꾼의 어설픈 글에 소중한 댓글 감사드립니다^^^
정말 감사드립니다. 좀더 더 공부해볼께요,,, 감사합니다^^^
파이썬3 드림
[크롬북에서 적었어요~]
ucs가 뭐냐면, 유니코드인데, 문자마다 번호가
ucs가 뭐냐면, 유니코드인데, 문자마다 번호가 매겨져있습니다.
예를 들면 "가"라는 문자는 AC00 이라는 번호가 매겨져있습니다.
아래처럼 하면 utf8 로 변환됩니다.
https://en.wikipedia.org/wiki/UTF-8#Examples
지금은 이해를 못하지만 노력 해볼께요,,,
지금은 이해를 못하지만 노력 해볼께요,,,
감사합니다 호동님^^^
(소중한 코드도 땅에 떨어지지 않도록 99.9% 이해할 수 있도록 노력할께요)
파이썬3 드림
[우분투 18.04 파여폭스 나비에서 적었어요~]
댓글 달기