- 浏览: 161803 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
semmy:
赞一个
displaytag的Excel导出实践 -
李君寻:
...
displaytag的Excel导出实践 -
xiaoz170:
不太明白为嘛包这一层 class ,反而使代码更复杂。难道是为 ...
试读《基于MVC的JavaScript Web富应用开发》— 不一样的JavaScript -
lingceng:
<mirror> <id>U ...
maven usage guide
总结:
从下面的代码可以看出,C中几乎所有函数都需要持有list指针,而且在使用上也十分麻烦,需要在主函数中维护头指针。sdfdf
Java用了三个文件,ListNode.java,List.java还有一个Test.java。从下面贴出的List.java的代码可以看出,函数实现相对简单一些,不必要维护list指针,因为有对象属性存在。这里可以看出一些面向对象编程的好处。
LinkedList.c:
List.java
所有Java代码见附件
从下面的代码可以看出,C中几乎所有函数都需要持有list指针,而且在使用上也十分麻烦,需要在主函数中维护头指针。sdfdf
Java用了三个文件,ListNode.java,List.java还有一个Test.java。从下面贴出的List.java的代码可以看出,函数实现相对简单一些,不必要维护list指针,因为有对象属性存在。这里可以看出一些面向对象编程的好处。
LinkedList.c:
#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct node_s { void *data; struct node_s *next; } NODE; NODE *list_create(void *data) { NODE *node; if (!(node = malloc(sizeof(NODE)))) { return NULL; } node->data = data; node->next = NULL; return node; } NODE *list_insert_after(NODE *node, void *data) { NODE *newnode; newnode = list_create(data); newnode->next = node->next; node->next = newnode; return newnode; } NODE *list_insert_beginning(NODE *list, void *data) { NODE *newnode; newnode = list_create(data); newnode->next = list; return newnode; } int list_remove(NODE *list, NODE *node) { while (list->next && list->next != node) { list = list->next; } if (list->next) { list->next = node->next; free(node); return 0; } else { return -1; } } int list_foreach(NODE *node, int (*func)(void *)) { while (node) { if (func(node->data) != 0) return -1; node = node->next; } return 0; } NODE *list_find(NODE *node, int (*func)(void *, void *), void *data) { while (node) { if (func(node->data, data) > 0) { return node; } node = node->next; } return NULL; } int printstring(void *s) { printf("%s\n", (char *)s); return 0; } int findstring(void *listdata, void *searchdata) { return strcmp((char*)listdata, (char *)listdata) ? 0 : 1; } int main() { NODE *list, *second, *inserted; NODE *match; /* Create initial elements of list */ list = list_create((void *)"First"); second = list_insert_after(list, (void *)"second"); list_insert_after(second, (void *)"Third"); printf("Initail list:\n"); list_foreach(list, printstring); putchar('\n'); /* Insert one extra element in the beginning */ list = list_insert_beginning(list, "BeforeFirst"); printf("After list_insert_beginning():\n"); list_foreach(list, printstring); putchar('\n'); /* Insert one extra element after second */ inserted = list_insert_after(second, "AfterSecond"); printf("After list_insert_after():\n"); list_foreach(list, printstring); putchar('\n'); /* Remove the element */ list_remove(list, inserted); printf("After list_remove():\n"); list_foreach(list, printstring); putchar('\n'); /* search */ if ((match = list_find(list, findstring, "Third")) != NULL) { printf("Found \"Third\"\n"); } else { printf("Did not find \"Third\"\n"); } return 0; }
List.java
package com.lingceng; import com.lingceng.util.ListNode; public class List { private ListNode root; private int max = 10; private int number; public List() { this.root = null; this.number = 0; } public ListNode getRoot() { return this.root; } public int getNumber() { return this.number; } public int getMax() { return this.max; } public void setRoot(ListNode root) { this.root = root; } public void insertAfter(int value) { ListNode tmp = new ListNode(value); ListNode tmp2 = this.root; if (this.number == this.max) { System.out.println("insert full list"); return; } while (tmp2.getNext() != null) { tmp2 = tmp2.getNext(); } tmp2.setNext(tmp); this.number++; } public void insertBeginning(int value) { ListNode tmp = new ListNode(value, this.root); if (this.number == this.max) { System.out.println("insert full list"); return; } this.root = tmp; this.number++; } public void removeIndex(int n) { ListNode tmp = this.root; if (this.root == null) { return; } if (n == 0) { this.root = this.root.getNext(); return; } for(int i = n; i > 1; i--) { if(tmp.getNext() == null) { return; } tmp = tmp.getNext(); } tmp.setNext(tmp.getNext().getNext()); this.number--; } public void removeValue(int value) { ListNode tmp = this.root; if (this.root == null) { return; } if (this.root.getValue() == value) { this.root = this.root.getNext(); return; } while (tmp.getNext().getValue() != value) { tmp = tmp.getNext(); if (tmp.getNext() == null) { return; } } tmp.setNext(tmp.getNext().getNext()); this.number--; } @Override public String toString() { ListNode tmp = this.root; if (this.root == null) { return "Empty List"; } StringBuffer sb = new StringBuffer(); while (tmp != null) { sb.append(tmp.getValue()); if (tmp.getNext() != null) { sb.append("->"); } tmp = tmp.getNext(); } return sb.toString(); } }
所有Java代码见附件
- list.tar (10 KB)
- 下载次数: 0
发表评论
-
Hack struts2 json plugin: dynamically set includeProperty
2013-07-26 11:27 1323Here is not basic use of stru ... -
Calender to Date snip
2013-05-30 10:25 951The format is not stored in the ... -
Gson切面日志实践
2013-02-26 17:47 2409背景 应用切面做日志记录,记录操作实体详情时可以使用JSO ... -
读《深入分析Java Web技术内幕》
2013-01-16 21:37 3356这里这本书的预读章节,看完预读部分,解答了一些疑惑 ... -
Java泛型
2012-11-08 23:57 1630Java的泛型是5.0的特性,自己的业务代码中或许较少使用 ... -
lucene全文索引
2012-11-08 01:45 1543总听说lucene,总听到“全文检索”,一直不大明白什么意 ... -
displaytag的汇总功能
2012-11-07 10:39 1092displaytag 有列汇总功能,以前不知道step1:需要 ... -
native2ascii使用
2012-10-29 13:56 1226native2ascii -[options] [inputf ... -
有效使用Java异常
2012-10-26 15:58 939Java的异常机制是一大优点,可以快速定位错误。但在实际开 ... -
从springside看到的
2012-10-26 00:27 1177springside是一个JAVAEE的开发框架,作者运用 ... -
JSTL小结
2012-10-12 12:00 1117网上有很多内容讲解, ... -
memcache simple practice in Java
2012-09-24 17:58 1671Memcache is C/S structure, serv ... -
displaytag中使用struts的国际化资源
2012-07-30 19:09 1414使用displaytag打印表格的时候,表头有时需要使 ... -
newInstance() and new
2012-07-11 14:00 1055相同点 newInstance() and new can ... -
Java Decompile
2012-07-05 15:58 1002较早的eclipse的Java反编译是jad.exe ... -
Use JUnit
2012-07-05 13:20 938Junit A programmer-oriented te ... -
Use JUnit (2)
2012-07-05 13:04 910Junit3 diff Junit4 包命名从 ... -
Develop C with vim
2012-05-31 11:15 1079OS:Ubuntu12.04Vim version:7.3A ... -
《Java语言精粹》读书笔记(3)
2012-04-27 15:13 953集合 数据结构中的关于大型结构在java.util中提 ... -
《Java语言精粹》读书笔记(2)
2012-04-27 14:37 1040Package Like most objec ...
相关推荐
### Amazon SimpleDB JAVA API 文档详解 #### 一、引言与概述 Amazon SimpleDB 是一个高度可用且灵活的非关系型数据存储服务,适用于云端应用程序。它为开发者提供了简单的 API 接口来存储和查询数据,而无需管理...
A general familiarity with object-oriented programming concepts and the Java programming language is necessary. The Java language essentials tutorial can help. copyright 1996-2000 Magelang ...
Automatic conversion between C and Java strings, with customizable encoding/decoding Structure and Union arguments/return values, by reference and by value Function Pointers, (callbacks from native...
And feel free to ask questions on the mailing list if you encounter any problems with the software! I am sure it is far from perfect... Downloads To install manually the JAR files, obtain the ...
Java 1.6提供了SAX(Simple API for XML)、DOM(Document Object Model)和JAXB(Java Architecture for XML Binding)等API来解析、操作和生成XML文档。 12. **安全管理**: Java的权限模型在1.6中进一步完善,...
You must have a good knowledge of Java programming and be familiar with the basics of Spring. Table of Contents Creating an Application to List World Countries with their GDP Building a Reactive ...
Continuous compilation and testing with triggered execution Packages and publishes jars Generates documentation with scaladoc Supports mixed Scala/Java projects Supports testing with ScalaCheck, specs...
One of the strong features of java is that it is follows a OOPs concept, and one of the feature of OOP in java is that, we can assign a subclass object or variable to the variable of the superclass ...
including C#, C++, C, Java™, Android™ app development, iOS app development, Swift™, Visual Basic®, Python™ and Internet and web programming. Features: Use with Windows® 7, 8 or 10. Integrated...
markovlet.c -- Letter-level markov text, simple algorithm. Appendix 3: Cost Models spacemod.cpp -- Space used by various records. timemod.c -- Table of times used by various C constructs. You may...
By covering a wide range of Java technologies and providing practical examples, this book equips readers with the knowledge and skills needed to enhance productivity and streamline development ...
It also ensures seamless interoperability with existing Android languages like JAVA and C++, which makes it easier to learn a new language for their most favored platform. This book adopts a project...
However, what happens when you're moving to a new system and you want to port your settings and customizations over along with UltraEdit? Add a webpage to your toolbar Use UltraEdit's powerful user ...
* [abc] a, b, or c (simple class) [abc] a, b, 或 c (简单字符串) * [^abc] Any character except a, b, or c (negation) [^abc] 除了 a, b, 或 c 之外的任意字符(否定) * [a-zA-Z] a ...
要实现这个功能,我们需要使用Java的标准库JAXB(Java Architecture for XML Binding)或者DOM(Document Object Model)、SAX(Simple API for XML)等解析器。下面我们将详细介绍如何在Java中读取XML文件。 1. ...
- **Appendix C: Plug-in Extension Points**: List of available extension points for extending Eclipse plug-ins. - **Appendix D: Introduction to SWT**: Overview of Standard Widget Toolkit (SWT), a ...
- **C++ Compared with Java:** Compares C++ with Java, highlighting differences in syntax and features. ### Chapter 2: Native Types and Statements Chapter 2 delves deeper into the native types and ...
Other books in the series use languages like Java and Python, but all focus on concepts and not on any particular language. The presentation of the material is the same in each language, and much of ...